[英]Loop through an Associative Arrays after parsing an XML document
我使用了一个类来解析XML文件。 XML文件如下所示:
<?xml version="1.0" encoding="utf-8"?>
<user>
<name id="1">John Mal</name>
<addr>123 N 45</addr>
<phone id="5">555.55.222</phone>
</user>
解析的结果是一个关联数组:
Array (
[0] => Array (
[name] => USER
[content] =>
[child] => Array(
[0] => Array(
[name] => NAME
[attrs] => Array([ID] => 1)
[content] => John Mal
)
[1] => Array(
[name] => ADDR
[content] => 123 N 45
)
[2] => Array(
[name] => PHONE
[attrs] => Array([ID] => 5)
[content] => 555.55.222
)
)
)
)
我的问题是如何遍历数组并获取内部信息。 例如,我想获得第一个id
和name
-tag的内容,因此要在单独的一行中输入,因为在此之后,我想将所有信息写入文本文件中。 怎么做? 任何帮助都非常感谢。
该解析函数对于您要实现的目标似乎并不特别有用。
您可能对SimpleXML感兴趣。
<?php
$user = new SimpleXMLElement(data());
echo 'name=', $user->name,' id=', $user->name['id'], PHP_EOL;
echo 'addr=', $user->addr, PHP_EOL;
echo 'phone=', $user->phone,' id=', $user->phone['id'], PHP_EOL;
function data() {
return <<< eox
<?xml version="1.0" encoding="utf-8"?>
<user>
<name id="1">John Mal</name>
<addr>123 N 45</addr>
<phone id="5">555.55.222</phone>
</user>
eox;
}
我会为诸如DOM
或SimpleXml
类的解析器投票,以获取数组上的强大功能。 如果您必须使用数组...
这是直接访问复杂数组中特定基准的方法:
var_dump($a[0]['child'][0]['content']);
输出:
string(8) "John Mal"
迭代:
foreach ($a as $set) {
echo $set['name'] . PHP_EOL;
echo $set['content'] . PHP_EOL;
echo "----------------" . PHP_EOL;
foreach ($set['child'] as $item) {
foreach ($item as $key => $value) {
echo "$key: $value" . PHP_EOL;
}
}
}
输出:
USER
CONTENT
----------------
name: NAME
attrs: Array
content: John Mal
name: ADDR
content: 123 N 45
name: PHONE
attrs: Array
content: 123.345
在实际操作中查看并尝试使用它: https : //eval.in/530409
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.