xml - 创建一个可以导入到 EXCEL 的 XSD,具有基于元素值的限制

标签 xml excel xsd xsd-validation restrictions

我已经在网上搜索了一段时间,据我所知,我想要使用 XSD 1.0 是不可能的。我的要求是:

我们有一个 .xml 在导入到 excel 时创建下表:

enter image description here

要求只有一个,即 Bird 1、2、3 下的值限制在每个特征的每个 Min 和 Max 的范围内。

例如,鸟 1 的体重必须在 10-20 之间,但鸟 1 的高度必须在 3-9 之间。

在 Bird 3 下,体重和高度不是有效的方法,因为它们超出了它们的最小-最大范围。

现在我需要制作一个可以导入 Excel 的 XSD 文件,并且它会创建使上述工作正常的限制。

我制作的 XSD 是:

    xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
  <xs:element name="Root">
    <xs:complexType>
      <xs:sequence>
        <xs:element name="Row" maxOccurs="unbounded" minOccurs="0">
          <xs:complexType>
            <xs:sequence>

              <xs:element type="xs:string" name="Feature"/>           
              <xs:element type="xs:int" name="Min"/>              
              <xs:element type="xs:int" name="Max"/>              
              <xs:element name="Bird 1">
                  <xs:simpleType>
                    <xs:restriction base="xs:int">
                        <xs:minInclusive value="X"/> <!-- X= The Min value -->
                        <xs:maxInclusive value="Y"/> <!-- Y= The Max value -->
                    </xs:restriction>
                  </xs:simpleType>
              </xs:element>           
              <xs:element name="Bird 2">
                  <xs:simpleType>
                    <xs:restriction base="xs:int">
                        <xs:minInclusive value="X"/>  <!-- X= The Min value -->
                        <xs:maxInclusive value="Y"/>  <!-- Y= The Max value -->
                    </xs:restriction>
                  </xs:simpleType>
              </xs:element>           
              <xs:element name="Bird 3">
                  <xs:simpleType>
                    <xs:restriction base="xs:int">
                        <xs:minInclusive value="X"/>  <!-- X= The Min value -->
                        <xs:maxInclusive value="Y"/>  <!-- Y= The Max value -->
                    </xs:restriction>
                  </xs:simpleType>
              </xs:element>

            </xs:sequence>
          </xs:complexType>
        </xs:element>       
      </xs:sequence>      
    </xs:complexType>
  </xs:element>
</xs:schema>

上面的 XSD 只有在限制值中有固定数字时才有效。

理想情况下,我希望限制 minInclusive 和 maxInclusive 值指向 Min Max 元素。

如果我可以使用 XSD 1.1 或其他类似 schematron 的东西,那将是可行的。但是因为我需要将 xsd 导入 Excel,所以我不得不使用 XSD 1.0。

我目前正在尝试根据示例 sample 找出一种使用 Key 和 Key-ref 的方法。但到目前为止我没有运气。

有什么建议或解决方法可以使这项工作???

先感谢您

最佳答案

实际上,使用 XML Schema 1.1,您可以使用 XPath 定义更多约束。

不过,我对数据模型有意见。简而言之,我建议在逻辑级别交换行和列。如果我正确地假设新鸟会比新功能更频繁地添加,则应该为此优化架构,这恰好可以规避问题。

如果预先知道鸟类的特征(年龄、体重、高度)或很少更改,我会将它们视为 XML 模式类型而不是行。这样,最小值和最大值可以存储在 XML Schema 中(如上所述)并将适用于所有鸟类,这应该可以通过 XML Schema 1.0 实现。

然后鸟类可以成为一等公民并成为“XML 行”,而它们的特征可以成为它们的属性(但没有什么能阻止它们在 excel 中显示为列,并将它们的子元素显示为行):

<birds>
  <bird id="Bird 1">
    <age>5</age>
    <weight>15</weight>
    <height>4</height>
  </bird>
  <bird id="Bird 2">
    <age>9</age>
    <weight>12</weight>
    <height>7</height>
  </bird>
  <bird id="Bird 3">
    <age>2</age>
    <weight>22</weight>
    <height>2</height>
  </bird>
</birds>

关于xml - 创建一个可以导入到 EXCEL 的 XSD,具有基于元素值的限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47122700/

相关文章:

android - 我的 Android Eclipse Developer 应用程序中有 2 个 AndroidManifest.xml 文件,我应该编辑哪一个?

c++ - 无法使用 node.value() 获取 pugixml 中 XML 元素的值

xml - XSL value-of 似乎没有从 xml 中获取值

Excel:禁用有关尝试在 BeforeDoubleClick 上更改 protected 单元格的警报

xml - 要求(允许) "xml:base"- XML 模式中的属性

具有属性的元素中的 xml 模式嵌套元素

xml - jaxb 混合 XmlElement 和 XmlValue

java - 简单的 : Element declared twice

c# - 当 Excel 保存文档时,如何在编辑后保留 OpenXml 单元格属性?

excel - 将不同范围添加到图表中的同一系列