Serialize branch data by ‘jsondata.JSONDataSerializer’¶
The module jsondata.JSONDataSerializer extends the JSONData class with serialization for JSON documents and substructures.
Provided basic operations are:
- json_import: Import a document or a branch into a document.
- json_export: Export a document or a branch.
Syntax Elements¶
The current release provides the following operators for the class ‘JSONPointer’.
Import/Export Operations:
ops := json_import | json_export
Examples¶
Examples for the provided basic calculations are:
Import-Document¶
Branch Operations - import a JSON document:
# persistent file sources datafile = os.path.abspath(os.path.dirname(__file__))+os.sep+str('datafile.json') schemafile = os.path.abspath(os.path.dirname(__file__))+os.sep+str('schema.jsd') # # set some control keys for the import, refer to API # kargs = {} kargs['datafile'] = datafile kargs['schemafile'] = schemafile kargs['nodefaultpath'] = True kargs['nosubdata'] = True kargs['pathlist'] = os.path.dirname(__file__) kargs['validator'] = MODE_SCHEMA_DRAFT4 # load JSON data, with validation by draft4 configdata = ConfigData(appname,**kargs)
Import-Branch¶
Branch Operations - import a JSON branch:
# Import another branch into initial main/master data, # and validate it with branch schema. # Use insertion point: # target = configdata.data['phoneNumber'] # partial schema for branch, use here a subtree of main schema, schema = { "$schema": "http://json-schema.org/draft-03/schema", 'phoneNumber':configdata.schema['properties']['phoneNumber'] } # import settings kargs = {} kargs['schema'] = schema kargs['nodefaultpath'] = True kargs['nosubdata'] = True kargs['pathlist'] = os.path.dirname(__file__) kargs['validator'] = MODE_SCHEMA_DRAFT4 # target container target = configdata.data['phoneNumber'] # do it... datafile = os.path.abspath(os.path.dirname(__file__))+os.sep+str('branch1.json') # use '*args' here ret = configdata.json_import(target, '-', datafile, None, **kargs) assert ret == True
Export-Document¶
Branch Operations - export a JSON document:
# # Export the document. # datafile = os.path.abspath(os.path.dirname(__file__))+os.sep+str('export-doc.json') ret = configdata.json_export(None, datafile) assert ret == True
Export-Branch¶
Branch Operations - export a JSON branch:
# # Export a branch. # datafile = os.path.abspath(os.path.dirname(__file__))+os.sep+str('export-doc.json') branch = JSONPointer('/phoneNumber/0').get_node(configdata.data) ret = configdata.json_export(branch, datafile) assert ret == True