xs:pattern 是 XSD 中用于正则约束的机制,必须嵌套在 xs:simpleType 的 xs:restriction 内,基于 XML Schema 正则子集,自动全字符串匹配,不支持反向引用等高级特性。

xs:pattern 是 XSD 中用于对元素或属性值施加正则表达式约束的关键机制,它必须放在 xs:simpleType 的 xs:restriction 内部使用。
基本用法:在 simpleType 中嵌套 pattern
不能直接给 xs:element 加 xs:pattern,必须先定义一个带限制的简单类型:
- 先用
xs:simpleType包裹xs:restriction - 在
xs:restriction中指定base(如xs:string) - 再添加一个或多个
xs:pattern,每个value属性写正则表达式
示例:要求手机号为 11 位数字,且以 1 开头
<xs:simpleType name="PhoneNumber"><xs:restriction base="xs:string">
<xs:pattern value="1\d{10}"/>
</xs:restriction>
</xs:simpleType>
正则语法注意点:XSD 使用 XML Schema 正则子集
XSD 的正则不是完整 JavaScript 或 Java 风格,而是基于 XML Schema Part 2 规范 的精简版,不支持:
- 反向引用(
\1)、前瞻断言((?=...))、懒惰匹配(*?) -
\d、\w、\s可用,但部分处理器可能要求写成[0-9]等显式形式 - 所有匹配默认是**全字符串匹配**,即自动锚定在 ^ 和 $ 位置,不用手动加
- 如果要允许多个可选格式,可写多个
xs:pattern(逻辑是“或”关系)
常见实用例子
✅ 邮箱(简化版,仅示意):
<xs:pattern value="[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}"/>✅ 身份证号(18 位,末位可能是 X):
<xs:pattern value="\d{17}[\dXx]"/>✅ 日期格式 YYYY-MM-DD:
<xs:pattern value="\d{4}-(0[1-9]|1[0-2])-(0[1-9]|[12]\d|3[01])"/>⚠️ 注意:XSD 不校验日期有效性(如 2023-02-30 仍会通过),只做格式匹配。
配合元素或属性使用
定义好类型后,在 xs:element 或 xs:attribute 中引用即可:
<xs:attribute name="code" type="PhoneNumber"/>
或者直接内联定义(适合局部使用):
<xs:element name="phone"><xs:simpleType>
<xs:restriction base="xs:string">
<xs:pattern value="1\d{10}"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
基本上就这些。关键是记住 pattern 必须嵌在 restriction 里,正则写法有约束,别套用其他语言的习惯。










