cdekok/xml-transform
最新稳定版本:1.1.3
Composer 安装命令:
composer require cdekok/xml-transform
包简介
XML to Array transformer
关键字:
README 文档
README
PHP XML Transformer
This library is useful to map xml values to array values, with xpath queries.
Installation
composer require cdekok/xml-transform
Usage
List of data
// Optional add namespaces in the XML $namespaces = ['oai' => 'http://www.openarchives.org/OAI/2.0/']; // Define the mapping for the array that you want to have filled $mapping = [ 'id' => [ 'xpath' => './/oai:identifier/text()' ], 'material' => [ 'xpath' => './/oai:material/text()', 'repeatable' => true // If elements are repeatable set this option so an array will be returned ], ]; $data = (new \XmlTransform\Mapper($mapping, '//oai:OAI-PMH/oai:ListRecords/oai:record', $namespaces)) ->from('somefile.xml') ->transform(); // $data will contain something like [ ['id' => '12', 'material' => ['paint', 'pencil']], ['id' => '13', 'material' => ['pen', 'pencil']], ]
Single array
For convience it's also possible to only map to 1 array instead of a list of results.
$data = (new \XmlTransform\Mapper($mapping, '//oai:OAI-PMH/oai:ListRecords/oai:record', $namespaces)) ->from('somefile.xml') ->transformOne(); // $data will contain something like ['id' => '12', 'material' => ['paint', 'pencil']]
Repeatable nested elements
$mapping = [ 'id' => ['xpath' => './/oai:objectid/text()'], 'creator' => [ 'repeatable' => true, // Mark the element as repeatable 'context' => './/oai:constituent', // new context for the nested elements 'values' => [ 'name' => ['xpath' => './/text()'], 'death_date' => ['xpath' => './/@death_date'], ] ] ]; $transformer = new \XmlTransform\Mapper($mapping, '//oai:record', $namespaces); $result = $transformer->from($xml)->transformOne(); // Result will contain something like this [ 'id' => '3517', 'creator' => [ ['name' => 'Rembrandt', 'death_date' => '1669'], ['name' => 'Johannes Mock', 'death_date' => '1884'], ['name' => 'Georg Friedrich Schmidt', 'death_date' => '1775'], ] ]
Filter values
Filter empty values from the returned array
$transformer->from($xml)->filter()->transform();
Optional elements (contexts)
If there are optional elements with a context in the xml you will need to enable the optional setting to prevent an ContextNotFoundException
$mapping = [ 'record' => [ 'context' => './/data', 'values' => [ 'title' => ['xpath' => './/title/text()'], 'creator' => ['xpath' => './/creator/text()'], // optional ] ], ]; $transformer = new \XmlTransform\Mapper($mapping, '//record'); $result = $transformer->from($xml)->optionalElements()->filter()->transform(); // Result creator is missing. [ 'record' => [ 'title' => 'test', 'creator' => 'Bert', ], ], [ 'record' => [ 'title' => 'test 2', ] ]
Development
After running composer install grumphp will watch codestyles and unit tests before commits.
To manually check the code style / unit tests run composer run test
To format the code automatically run composer run format
To generate test coverage run composer run report
This project follows git flow for commits
统计信息
- 总下载量: 5.62k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2016-11-26