EXPath 是社区推动的XML处理扩展函数规范集合,弥补XPath标准缺失功能,支持文件读写、HTTP请求、ZIP/JSON处理等,跨平台开源,需处理器显式支持。

EXPath 并不是 XPath 官方标准的一部分,而是一个由社区推动的、面向 XML 处理的**扩展函数规范集合**,目标是弥补 W3C XPath 1.0/2.0/3.x 标准中缺失的实用能力。它不隶属于 Microsoft 或 W3C,而是由独立开发者和开源项目(如 BaseX、eXist-db)共同维护与实现的模块化函数库。
EXPath 的核心定位
它把原本需要外部程序完成的任务——比如读写文件、调用 HTTP 接口、处理 ZIP 包、解析 JSON、操作日期时间、生成 UUID 等——封装成可在 XPath 表达式中直接调用的函数。简单说:让 XPath 不再只是“查数据”,还能“做事情”。
常见 EXPath 模块举例
每个模块解决一类实际问题,典型包括:
- file:read-text() —— 从本地或远程 URL 读取文本内容,直接在 XPath 中加载配置或模板
- http:send-request() —— 发起 GET/POST 请求,把 XPath 变成轻量级 API 调用器
- zip:entries() 和 zip:unzip() —— 解析 ZIP 文件结构并提取其中的 XML 或文本
- json:parse() 和 json:serialize() —— 在 XPath 表达式里无缝转换 JSON 与 XML/序列化格式
- datetime:current-dateTime() —— 提供比原生 XPath 更丰富的时区、格式化、运算支持
和 Microsoft XPath 扩展函数的区别
Microsoft 的扩展函数(如 ms:string-compare、ms:number-compare)主要面向 .NET 平台兼容性与 XSD 类型增强,属于专有实现,仅在 IE/MSXML 或旧版 Office 场景中有效;而 EXPath 是跨平台、开源、可移植的规范,被 BaseX、eXist-db、Saxon-PE/EE(需启用)等现代处理器支持,更贴近现代 Web 和数据集成需求。
技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作
怎么用?关键看处理器是否支持
EXPath 函数不能“开箱即用”,必须满足两个条件:
- 你使用的 XML/XPath 引擎明确声明支持 EXPath(例如 BaseX v9.6+ 默认启用部分模块)
- 对应模块已正确加载(有些需手动注册 JAR 或启用插件)
- 命名空间必须正确声明,例如:
declare namespace file = "http://expath.org/ns/file";
在 Python 的 lxml 中——目前不支持 EXPath。lxml 只实现 XPath 1.0 核心函数,所有 EXPath 功能需借助外部 Python 代码完成,无法在 .xpath() 字符串中直接调用。









