将XML转为PHP数组有五种方法:一、SimpleXML+JSON中转;二、DOMDocument递归构建;三、xml_parser_create事件驱动;四、spatie/xml-to-array库;五、命名空间XML适配方案。

如果您需要将XML文件的内容转换为PHP数组以便于后续处理,则可能是由于PHP原生数组操作比XML对象更直观。以下是将XML文件读取并解析为PHP数组的多种方法:
一、使用simplexml_load_file配合json_encode/json_decode
该方法利用SimpleXML将XML解析为对象,再通过JSON中转实现数组化,适用于结构较规范、无重复同名子节点的XML文件。
1、使用simplexml_load_file()函数加载XML文件,返回SimpleXMLElement对象。
2、调用json_encode()将该对象转换为JSON字符串。
立即学习“PHP免费学习笔记(深入)”;
3、使用json_decode()并将第二个参数设为true,将JSON字符串解码为关联数组。
4、检查返回值是否为数组,若为null则说明XML格式有误或编码不兼容。
二、使用DOMDocument配合递归函数解析
该方法通过DOMDocument加载XML,再以递归方式遍历所有节点,手动构建嵌套数组,可精确控制键名、处理重复标签及属性,并保留文本内容与子元素的区分。
1、实例化DOMDocument对象,调用load()方法加载XML文件路径。
2、获取documentElement属性获得根节点。
3、编写递归函数,对每个DOMNode判断节点类型:ELEMENT_NODE时提取tagName、attributes和childNodes;TEXT_NODE时提取trim后的nodeValue。
4、对每个属性生成形如'@属性名'的键,对子元素按标签名聚合,若同名子元素超过一个则自动转为索引数组。
三、使用xml_parser_create创建事件驱动解析器
该方法基于PHP内置的Expat XML解析器,以事件回调方式逐段处理开始标签、结束标签与字符数据,内存占用低,适合大体积XML文件流式解析。
1、调用xml_parser_create()创建解析器资源,并设置UTF-8编码。
2、使用xml_set_element_handler()注册startElement和endElement回调函数,分别处理标签开启与闭合。
3、使用xml_set_character_data_handler()注册characterData回调,捕获标签内纯文本。
4、在startElement中根据当前深度和标签名动态构建数组路径,在characterData中写入对应位置的值,遇到同级同名标签时自动追加至数组尾部。
四、使用第三方库spatie/xml-to-array
该方法引入Composer管理的轻量库,内部已封装DOMDocument递归逻辑,支持自定义选项如是否忽略属性、是否合并单子节点为值等,提升开发效率。
1、执行composer require spatie/xml-to-array安装依赖包。
2、使用file_get_contents()读取XML文件内容为字符串。
3、调用Spatie\XmlToArray\XmlToArray::convert()传入XML字符串,返回标准PHP数组。
4、可通过传递$options参数控制行为,例如['always_array' => ['item']]表示强制将所有名为item的节点转为数组。
五、处理命名空间XML的适配方案
当XML包含命名空间(如xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance")时,SimpleXML默认无法直接访问带前缀的节点,需显式注册命名空间或使用XPath查询。
1、若使用SimpleXML,加载后调用registerXPathNamespace()注册前缀与URI映射关系。
2、改用xpath()方法结合命名空间前缀定位节点,再逐个提取并构造数组结构。
3、若使用DOMDocument,需在load后调用getElementsByTagNameNS(),传入命名空间URI和局部名称。
4、注意未声明默认命名空间时,节点实际属于空命名空间,不可用前缀匹配。











