1

我正在从 MySQL 数据库中获取大量 XML 数据并尝试解析出相关信息。有一个ArrayOfString我以前从未见过的,但是我需要从中获取值以供使用。

我尝试了几种方法,包括 SimpleXML's __ToString(),使用(string)等等,但没有运气。如何正确地将其转换为可以分解为数组的字符串或仅转换为数组?

        $game_ids = $machine_xml->add[25]->attributes()->value[0];
        var_dump($game_ids);

结果:

object(SimpleXMLElement)#2 (1) {
  [0]=>
  string(331) "<?xml version="1.0" encoding="utf-16"?>
<ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <string>7</string>
  <string>46</string>
  <string>4</string>
  <string>60</string>
  <string>5</string>
  <string>23</string>
  <string>50</string>
</ArrayOfString>"
}
4

1 回答 1

0

首先,您似乎将 XML 包装在 XML 中。也就是说,您的 XML 文档部分看起来像这样:

<add value="&lt;?xml version=&quot;1.0&quot; encoding=&quot;utf-16&quot;?&gt;&lt;ArrayOfString xmlns:xsi=&quot;http://www.w3.org/2001/XMLSchema-instance&quot; xmlns:xsd=&quot;http://www.w3.org/2001/XMLSchema&quot;&gt;  &lt;string&gt;7&lt;/string&gt;  &lt;string&gt;46&lt;/string&gt;  &lt;string&gt;4&lt;/string&gt;  &lt;string&gt;60&lt;/string&gt;  &lt;string&gt;5&lt;/string&gt;  &lt;string&gt;23&lt;/string&gt;  &lt;string&gt;50&lt;/string&gt; &lt;/ArrayOfString&gt;">

因此,您需要做的第一件事是获取 XML 的内部部分,并使用 SimpleXML 对其进行解析:

$game_ids = $machine_xml->add[25]->attributes()->value[0];
$inner_xml = (string)$game_ids;
$inner_sxe = simplexml_load_string($inner_xml);

现在,您有了一个相当简单的 XML 文档:一个<ArrayOfString>包含一系列元素的<string>元素。所以你可以用一个foreach语句循环它们,然后收集到一个数组中:

$array = [];
foreach ( $inner_sxe->string as $string_element ) {
      $string_value = (string)$string_element;
      $array[] = $string_value;
}
于 2017-03-03T12:11:26.870 回答