承接 gaarf/xml-to-php-array 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

gaarf/xml-to-php-array

最新稳定版本:v1.0

Composer 安装命令:

composer require gaarf/xml-to-php-array

包简介

XML to PHP array convertor

README 文档

README

Smart tool to convert your XML to PHP array.

Install and simply use

Use Composer:

composer require gaarf/xml-to-php-array

And then package will be automatically installed to your project and you can simply call:

$resultArray = Convertor::covertToArray($xml);

Documentation

One common need when working in PHP is a way to convert an XML document into a serializable array. If you ever tried to serialize() and then unserialize() a SimpleXML or DOMDocument object, you know what I’m talking about.

Assume the following XML snippet:

<tv> <show name="Family Guy"> <dog>Brian</dog> <kid>Chris</kid> <kid>Meg</kid> </show> </tv>

There’s a quick and dirty way to do convert such a document to an array, using type casting and the JSON functions to ensure there are no exotic values that would cause problems when unserializing:

$a = json_decode(json_encode((array) Convertor::covertToArray($s)), true);

Here is the result for our sample XML, eg if we print_r($a):

Array ( [show] => Array ( [@attributes] => Array ( [name] => Family Guy ) [dog] => Brian [kid] => Array ( [0] => Chris [1] => Meg ) ) ) 

Pretty nifty, eh? But maybe we want to embed some HTML tags or something crazy along those lines. then we need a CDATA node…

<tv> <show name="Family Guy"> <dog>Brian</dog> <kid>Chris</kid> <kid>Meg</kid> <kid><![CDATA[<em>Stewie</em>]]></kid> </show> </tv>

The snippet of XML above would yield the following:

Array ( [show] => Array ( [@attributes] => Array ( [name] => Family Guy ) [dog] => Brian [kid] => Array ( [0] => Chris [1] => Meg [2] => Array ( ) ) ) ) 

That’s not very useful. We got in trouble because the CDATA node, a SimpleXMLElement, is being cast to an array instead of a string. To handle this case while still keeping the nice @attributes notation, we need a slightly more verbose conversion function. This is my version, hereby released under a do-whatever-but-dont-sue-me license.

The result, for our Stewie snippet:

Array ( [show] => Array ( [@attributes] => Array ( [name] => Family Guy ) [dog] => Brian [kid] => Array ( [0] => Chris [1] => Meg [2] => <em>Stewie</em> ) ) ) 

Victory is mine! :D

Contributions

[clh-code#1] If a node has attributes, but contains only text, then the output will be an array with both @content and @attributes keys

[reggi#4] store root element tag name in @root

[janbarasek#13] Add support for PHP 7.1 + better code style.

[janbarasek#15] Rewrite repository as Composer package.

[roland-d#18] Treat empty node as string

统计信息

  • 总下载量: 42.51k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 2
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 29
  • 开发语言: PHP

其他信息

  • 授权协议: Unknown
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固