好的所以这是问题,使用 api (lyris hq) 我正在返回这个 xml 数据集
<DATASET>
<TYPE>success</TYPE>
<RECORD>
<DATA type="name" id="205199">Dev1</DATA>
<DATA type="messages">4</DATA>
<DATA type="last-sent">Jun. 26, 2012</DATA>
<DATA type="members">1</DATA>
<DATA type="status">active</DATA>
<DATA type="cache-time">2012-06-26T18:21:18+00:00</DATA>
</RECORD>
<RECORD>
<DATA type="name" id="206378">Dev2</DATA>
<DATA type="messages">1</DATA>
<DATA type="last-sent"></DATA>
<DATA type="members">2</DATA>
<DATA type="status">active</DATA>
<DATA type="cache-time">2012-05-31T14:47:12+00:00</DATA>
</RECORD>
<RECORD>
<DATA type="name" id="206379">Dev3</DATA>
<DATA type="messages">1</DATA>
<DATA type="last-sent"></DATA>
<DATA type="members">1</DATA>
<DATA type="status">active</DATA>
<DATA type="cache-time">2012-05-31T14:47:12+00:00</DATA>
</RECORD>
<RECORD>
<DATA type="name" id="206380">Dev4</DATA>
<DATA type="messages">1</DATA>
<DATA type="last-sent"></DATA>
<DATA type="members">1</DATA>
<DATA type="status">active</DATA>
<DATA type="cache-time">2012-05-31T14:47:12+00:00</DATA>
</RECORD>
</DATASET>
我正在尝试做的是使用 SimpleXMLElement 创建一个数组,以这种格式递归地使用它
$response = array(
'{listid (id attribute from name element)}' => array(
'{other attribute type}' => '{value}'
),
);
使用 dev1(第一条记录)的示例
$response = array(
'205199' => array(
'name' => 'Dev1',
'messages' => '4',
'last-sent' => 'Jun. 26, 2012',
'members' => '1',
'status' => 'active',
'cache-time' => '2012-06-26T18:21:18+00:00'
),
);
我和这里的网络团队的几位成员已经对此进行了一段时间的抨击,但无处可去,所以我希望我能从荨麻疹的头脑中得到一些帮助,可以这么说,哈哈
这是我最后一次尝试用来获得结果的一个可怜的例子,显然失败了
foreach ($responseobj->RECORD as $value) {
$returnarray[(string)$value->DATA['id']] = array();
foreach ($value->DATA as $k => $v) {
echo '<pre>';
print_r($v);
echo '</pre>';
$returnarray[(string)$v['id']] = array((string)$v['type'] => (string)$v,);
}
}