Heim >Backend-Entwicklung >PHP-Tutorial > xml转换成数组的有关问题

xml转换成数组的有关问题

WBOY
WBOYOriginal
2016-06-13 13:37:28709Durchsuche

xml转换成数组的问题
现有如下xml:

XML code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
<root>
<rows>
<errmsg text=""></errmsg>
<retvalue text="true"></retvalue>
</rows>
<records>
<productno text="000321"></productno>
<billno text=""></billno>
<orderno text="D004410439"></orderno>
<out_trade_no text="100001"></out_trade_no>
<plcprem text="0.0"></plcprem>
<orderprem text="50.0"></orderprem>
<commision text="0.0"></commision>
</records>
....
<root>

</root></root>

xml深度不确定但每个节点都有text属性,想转换成如下数组,有什么好办法吗
PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
Array
(
    [rows] => Array
        (
            [errMsg] => 
            [retValue] => true
        )
    [records] => Array
        (
            [productno] =>000321
            [billno] =>
            [orderno] =>D004410439
            [out_trade_no] => 100001
            [plcprem] =>0.0
            [orderprem] =>50.0
            [commision] =>0.0
        )
        .....
)




------解决方案--------------------
看看这个

http://weblog.thomassmart.com/2008/09/php-function-xml2array/
------解决方案--------------------
PHP code
$s =
<rows>
<errmsg text=""></errmsg>
<retvalue text="true"></retvalue>
</rows>
<records>
<productno text="000321"></productno>
<billno text=""></billno>
<orderno text="D004410439"></orderno>
<out_trade_no text="100001"></out_trade_no>
<plcprem text="0.0"></plcprem>
<orderprem text="50.0"></orderprem>
<commision text="0.0"></commision>
</records>

XML;
$obj = simplexml_load_string($s);
$r = array();
foreach($obj as $name=>$nodes) {
  foreach($nodes as $k=>$v) {
    $t = (array)$v->attributes()->text;
    $r[$name][$k] = $t[0];
  }
}
print_r($r);
<br><font color="#e78608">------解决方案--------------------</font><br>
探讨
PHP code
$s =









……
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel: 数据库连接有关问题 Nächster Artikel: mysql有关问题