XML拆分节点上。 值(XML Split Node on . value)

2019-10-20 08:03发布

我一直这么用了很多年,总能找到一个答案,但这个时候我有我自己完全迷路了。

我有一个XML文件,我想给compatbility分成良好的XML

`<product>
<item>
<partno>abc123</partno>
<Compatbility>model1: 110C, 115C, 117C. model2: 1835C, 1840C. model3: 210C, 215C, 3240C.</Compatbility>
</item>
</product>`

在Compatbility字模型的每个项目条目虽然改变:经过模型是永远存在一样是。 后的每个模型组。

我应该使用SimpleXML的DomXml或XPath得到以下结果

`<product>
<item>
<partno>abc123</partno>
<Compatbility>
<model>model1: 110C, 115C, 117C.</model>
<model>model2: 1835C, 1840C.</model> 
<model>model3: 210C, 215C, 3240C.</model>
</Compatbility>
</item>
</product>`

谢谢

Answer 1:

首先ofcourse,您需要将其转换成第一的东西,你可以操纵(阵列)。 然后通常的解析(使用爆炸)。 最终,你将需要重新创建一个新的XML。 考虑下面这个例子:

$xml_string = '<product><item><partno>abc123</partno><Compatbility>model1: 110C, 115C, 117C. model2: 1835C, 1840C. model3: 210C, 215C, 3240C.</Compatbility></item></product>';
$original_xml = simplexml_load_string($xml_string);
$data = json_decode(json_encode($original_xml), true);
$compatbility = $data['item']['Compatbility']; // get all compatibility values
// explode values
$compatbility = array_filter(array_map('trim', explode('.', $compatbility)));

$new_xml = new SimpleXMLElement('<product/>'); // initialize new xml
// add necessary values
$new_xml->addChild('item')->addChild('partno', $data['item']['partno']);
$new_xml->item->addChild('Compatbility');
// loop the values and add them as children
foreach($compatbility as $value) {
    $value = trim(preg_replace('/(\w+):/', '', $value));
    $new_xml->item->Compatbility->addChild('model', $value);
}
echo $new_xml->asXML(); // output as xml


Answer 2:

对于simplexml的,你可以运行一个正则表达式中的一个元素的文本值匹配。

然后,您可以删除所有内部文本,并添加解析结果作为新的子元素。

这可以用都是可以做的,你说:DOM文档,SimpleXMLElement对象 - 无论有或没有的XPath。

这里是SimpleXML中(一个注释例如在线演示 ):

<?php
/**
 * @link http://stackoverflow.com/q/24304095/367456
 * @link https://eval.in/164934
 */
$buffer = <<<XML
<product>
<item>
<partno>abc123</partno>
<Compatbility>model1: 110C, 115C, 117C. model2: 1835C, 1840C. model3: 210C, 215C, 3240C.</Compatbility>
</item>
</product>
XML;

# load the xml string
$xml = simplexml_load_string($buffer);

# obtain the element in question
$compatbility = $xml->item->Compatbility;

# parse it's inner text-value for the models by a regex
$pattern = '~(model\\d?: [^.]+\\.) ?~u';
$result  = preg_match_all($pattern, $compatbility, $matches);

# remove the text (so called simplexml self-reference)
$compatbility->{0} = '';

# add the parsed models as new model elements
foreach ($matches[1] as $model) {
    $compatbility->model[] = $model;
}

# output the xml
$xml->asXML('php://output');

它给人的输出是:

<?xml version="1.0"?>
<product>
<item>
<partno>abc123</partno>
<Compatbility><model>model1: 110C, 115C, 117C.</model><model>model2: 1835C, 1840C.</model><model>model3: 210C, 215C, 3240C.</model></Compatbility>
</item>
</product>


文章来源: XML Split Node on . value