使用XSD在XML中验证自定义日期和时间

时间:2015-02-09 13:20:25

标签: xml validation xsd

我必须验证日期格式为09.02.2015(DD.MM.YYYY)和时间14:05(HH:MM)的日期,但无法找到方法。

以下是一个例子:

XML:

<?xml version="1.0"?>
<root>
    <testdate>09.02.2015</testdate>
    <testtime>14:05</testtime>
</root>

XSD:

<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
           xmlns:sql="urn:schemas-microsoft-com:mapping-schema">
    <!-- Root element -->
    <xs:element name="root">
        <xs:complexType>
            <xs:sequence>
                <xs:element name="testdate" type="zsdate"/>
                <xs:element name="testtime" type="zstime"/>
            </xs:sequence>
        </xs:complexType>
    </xs:element>

    <!-- Date format used to validate dates formatted like 01.01.2015 -->
    <xs:simpleType name="zsdate">
        <xs:restriction base="xs:date">
            <xs:pattern value="^(0[1-9]|[12][0-9]|3[01]).(0[1-9]|1[012]).(19|20)\d\d$"/>
        </xs:restriction>
    </xs:simpleType>

    <!-- Time format used to validate times formatted like 11:55, 23:59 etc. -->
    <xs:simpleType name="zstime">
        <xs:restriction base="xs:time">
            <xs:pattern value="^(0[0-9]|[1][0-9]|2[1-3]):([0-5][1-9])$"/>
        </xs:restriction>
    </xs:simpleType>
</xs:schema>

我尝试使用notepad ++ XML插件和XML validator验证XML。

Notepad ++输出:

  

使用XML架构验证当前文件:

     

错误:元素'testdate':'09 .02.2015'不是原子类型'zsdate'的有效值。
  错误:元素'testtime':'14:05'不是   原子类型'zstime'的有效值。

使用Regular Expression Tester测试正则表达式时,它正确匹配 我尝试将类型从xs:datexs:time更改为xs:string,但验证结果是相同的。

知道我做错了吗?

2 个答案:

答案 0 :(得分:1)

您的日期和时间要求不是xs:datexs:time的正确限制。如果是这样的话,那么这些改变就行了(但不会像你想的那样紧张):

                <xs:element name="testdate" type="xs:date"/>
                <xs:element name="testtime" type="xs:time"/>

因此,要使用您的模式,您必须以xs:string为基础。您还必须考虑到在XSD的xs:pattern正则表达式中,在开头已经有一个隐式^锚点,在模式结尾处有一个$锚点。删除你添加的额外内容可以消除你遇到的问题。

XSD

<?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
           xmlns:sql="urn:schemas-microsoft-com:mapping-schema">
    <!-- Root element -->
    <xs:element name="root">
        <xs:complexType>
            <xs:sequence>
                <xs:element name="testdate" type="zsdate"/>
                <xs:element name="testtime" type="zstime"/>
            </xs:sequence>
        </xs:complexType>
    </xs:element>

    <!-- Date format used to validate dates formatted like 01.01.2015 -->
    <xs:simpleType name="zsdate">
        <xs:restriction base="xs:string">
            <xs:pattern value="(0[1-9]|[12][0-9]|3[01]).(0[1-9]|1[012]).(19|20)\d\d"/>
        </xs:restriction>
    </xs:simpleType>

    <!-- Time format used to validate times formatted like 11:55, 23:59 etc. -->
    <xs:simpleType name="zstime">
        <xs:restriction base="xs:string">
            <xs:pattern value="(0[0-9]|[1][0-9]|2[1-3]):([0-5][1-9])"/>
        </xs:restriction>
    </xs:simpleType>
</xs:schema>

答案 1 :(得分:1)

更好的是这样,验证HH:50:

<xs:pattern value="(0[0-9]|[1][0-9]|2[1-3]):([0-5][0-9])"/>