当前位置 : 主页 > 网页制作 > xml >

如何正确使用GenerateDS进行DDEX XML绑定

来源:互联网 收集:自由互联 发布时间:2021-06-13
我对 Python XML绑定感兴趣,因为它读取符合此模式的输入文件: http://ddex.net/xml/ern/341/release-notification.xsd 这个XSD依赖于其他一些,但最重要的是: http://ddex.net/xml/20120404/ddexC.xsd和 http://dde
我对 Python XML绑定感兴趣,因为它读取符合此模式的输入文件:
http://ddex.net/xml/ern/341/release-notification.xsd

这个XSD依赖于其他一些,但最重要的是:
http://ddex.net/xml/20120404/ddexC.xsd和
http://ddex.net/xml/20120404/ddex.xsd

我的第一次尝试是使用generateDS.如果我使用–no-process-includes,我能够成功生成release-notification.xsd的绑定:

./generateDS.py --no-process-includes -o release-notification.py release-notification.xsd

但是,这给我留下了一个大多数无用的Python对象,因为大多数ComplexTypes都是在ddexC.xsd中定义的.

如果我在没有–no-process-includes的情况下尝试它,我得到:

RuntimeError: Extension/restriction recursion detected.
Suggest you check definitions of types ArtistRole and ArtistRole.

提到的定义是这样的:

<xs:element name="ArtistRole" maxOccurs="unbounded" type="ddexC:ArtistRole">
....
<xs:complexType name="ArtistRole">
      <xs:simpleContent>
         <xs:extension base="ddex:ArtistRole">
....

所以似乎ddex和ddexC命名空间以某种方式混淆并创建循环引用.

有什么建议吗?

您可能需要查看具有ddex lint脚本的 https://github.com/ddexnet,您可以使用该脚本生成完整的python对象,这些对象根据位于 http://ddex.net/xml/2010/ern-main/32的完整ERN架构进行验证.

(linter也使用了引擎盖下的ddexC命名空间).

网友评论