EXPath 是社区推动的XML处理扩展函数规范集合,弥补XPath标准缺失功能,支持文件读写、HTTP请求、ZIP/JSON处理等,跨平台开源,需处理器显式支持。
EXPath 并不是 XPath 官方标准的一部分,而是一个由社区推动的、面向 XML 处理的**扩展函数规范集合**,目标是弥补 W3C XPath 1.0/2.0/3.x 标准中缺失的实用能力。它不隶属于 Microsoft 或 W3C,而是由独立开发者和开源项目(如 BaseX、eXist-db)共同维护与实现的模块化函数库。
它把原本需要外部程序完成的任务——比如读写文件、调用 HTTP 接口、处理 ZIP 包、解析 JSON、操作日期时间、生成 UUID 等——封装成可在 XPath 表达式中直接调用的函数。简单说:让 XPath 不再只是“查数据”,还能“做事情”。
每个模块解决一类实际问题,典型包括:
arse() 和 json:serialize() —— 在 XPath 表达式里无缝转换 JSON 与 XML/序列化格式Microsoft 的扩展函数(如 ms:string-compare、ms:number-compare)主要面向 .NET 平台兼容性与 XSD 类型增强,属于专有实现,仅在 IE/MSXML 或旧版 Office 场景中有效;而 EXPath 是跨平台、开源、可移植的规范,被 BaseX、eXist-db、Saxon-PE/EE(需启用)等现代处理器支持,更贴近现代 Web 和数据集成需求。
EXPath 函数不能“开箱即用”,必须满足两个条件:
declare namespace file = "http://expath.org/ns/file";
在 Python 的 lxml 中——目前不支持 EXPath。lxml 只实现 XPath 1.0 核心函数,所有 EXPath 功能需借助外部 Python 代码完成,无法在 .xpath() 字符串中直接调用。