bha*_*yal 5 python xml parsing xsd data-structures
我正在尝试从给定的 XML 模式生成 XML 文件。我已经能够使用 python 中的 pyxb 库来做到这一点。但问题是,随着 XSD 变得越来越大,不可能对每个标签进行手动编码。是否有任何 python 库可以从给定的 XSD 文件创建一个可以迭代的数据结构
小智 10
这个库似乎可以满足您的需求:https://pypi.org/project/xmlschema/
浏览文档后,我发现了这个代码示例:https ://xmlschema.readthedocs.io/en/latest/usage.html#xsd-declarations
>>> import xmlschema
>>> from pprint import pprint
>>> schema = xmlschema.XMLSchema('xmlschema/tests/test_cases/examples/vehicles/vehicles.xsd')
>>> schema.types
NamespaceView({'vehicleType': XsdComplexType(name='vehicleType')})
>>> pprint(dict(schema.elements))
{'bikes': XsdElement(name='vh:bikes', occurs=[1, 1]),
'cars': XsdElement(name='vh:cars', occurs=[1, 1]),
'vehicles': XsdElement(name='vh:vehicles', occurs=[1, 1])}
>>> schema.attributes
NamespaceView({'step': XsdAttribute(name='vh:step')})
Run Code Online (Sandbox Code Playgroud)
所以看起来它可以用来创建一个 python 数据结构,您可以从 XSD 文件中进行迭代。
这个问题也可能相关:How to conversion XSD to Python Class
Ald*_*ven -3
您可以从 XSD 文件生成 XML 文件:
import requests
with open('file.xsd', 'r') as f:
data = f.read()
r = requests.post('https://www.liquid-technologies.com/api/Converter', json={"Filename": "schema.xsd", "Type": "xsd", "Data": data, "TargetType": "xml", "Arguments": {"elementName": "Root", "elementNamespace": "", "addAnyAttributes": False, "addAnyElements": False, "forceOptionItemsToDepthOf": "4", "forceXsiNamespaceDelaration": False, "maxDepthToCreateOptionalItems": "7", "indent": "2", "indentChar": " ", "indentAttributes": False, "seed": "9722"}})
with open('file.xml', 'w') as f:
f.write(r.json()['Files'][0]['Data'])
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
25736 次 |
| 最近记录: |