XML到PHP数组问题 - 列被合并成一个单一的行,而不是多行

问题描述 投票:0回答:1

我已经完成了所有的以前的问题了,不能找到一个可行的解决方案。我还没有过去与XML工作,我感觉有点混乱。据我所知,在打印的SimpleXML当你看不到所有的数据,但我不能得到的数据来结束我想要的方式。

我已经从仅返回XML卷曲要求收集的数据如下:

<result>
  <header>
    <col>
      <label>Account Id</label>
    </col>
    <col>
      <label>Employee Id</label>
    </col>
    <col>
      <label>Username</label>
    </col>
    <col>
      <label>First Name</label>
    </col>
    <col>
      <label>Last Name</label>
    </col>
    <col>
      <label>New Status</label>
    </col>
    <col>
      <label>Old Status</label>
    </col>
    <col>
      <label>Changed</label>
    </col>
    <col>
      <label>Email</label>
    </col>
  </header>
    <body>
      <row>
      <col>4346088504</col>
      <col>6534</col>
      <col>Nalini.LastName</col>
      <col>Nalini</col>
      <col>LastName</col>
      <col>Terminated</col>
      <col>Active</col>
      <col>02/01/2019 12:58p</col>
      <col>email1</col>
    </row>
    <row>
      <col>32103136</col>
      <col>2835</col>
      <col>Karen.LastName</col>
      <col>Karen</col>
      <col>LastName/col>
      <col>Inactive</col>
      <col>LOA</col>
      <col>02/01/2019 07:27a</col>
      <col>email2</col>
    </row>
    <row>
      <col>4348430099</col>
      <col>6652</col>
      <col>elouise.LastName</col>
      <col>Elouise</col>
      <col>LastName</col>
      <col>Active</col>
      <col>LOA</col>
      <col>02/01/2019 07:20a</col>
      <col>email3</col>
    </row>
  </body>
 <footer/>
</result>

这是如下返回一个字符串,并保存在变量$ result

$result = simplexml_load_string(curl_exec($ch));
$result = $result->body;

没有去成一个长切线我已经尝试了许多不同的迭代/循环的所有领域不只是那些如我所输入的得到这个结构如下:

           $result = array(
                'employees' => array(
                    array(
                        'KronosUniqueID' => '4346088504',
                        'KronosID' => '6534',
                        'FirstName' => 'Nalini',
                        'LastName' => 'LastName'
                    ),
                    array(
                        'KronosUniqueID' => '32103136',
                        'KronosID' => '2835',
                        'FirstName' => 'Karen',
                        'LastName' => 'LastName'
                    )
                    array(
                        'KronosUniqueID' => '4348430099',
                        'KronosID' => '6652',
                        'FirstName' => 'Elouise',
                        'LastName' => 'LastName'
                    )
                )
            );

一些帮助将不胜感激。最终输出可以是一个对象,以及如果这是优选的。

php xml loops foreach simplexml
1个回答
0
投票

这是一个基本的实现来提取数据,因为你是重新贴标签的领域,你将不得不手动完成。展开的映射捕捉到你想要的数据。

$simpleXML = simplexml_load_string( $xml );
$output = array();
foreach( $simpleXML->xpath('//body/row') as $row )
{
  $output[] = array(
    'KronosUniqueID' => (int) $row->col[0],
    'KronosID' =>  (int) $row->col[1],
    'FirstName' => (string) $row->col[3],
    'LastName' => (string) $row->col[4],
  );
}

下面是使用带有标签校正标签的“自动”的版本。

$simpleXML = simplexml_load_string( $xml );

$labels = (array) $simpleXML->xpath('//header/col/label');
$labels[0] = 'KronosUniqueID';
$labels[1] = 'KronosID';
$labels = array_map( function( $string ){ return str_replace( ' ', '', $string ); }, $labels ); // removes space character

$output = array();
foreach( $simpleXML->xpath('//body/row') as $row )
{
  $output[] = array_combine( $labels, (array) $row->col );
}
© www.soinside.com 2019 - 2024. All rights reserved.