我正在使用php访问wsdl webservice。读出效果很好,但解析结果似乎有点困难:我尝试使用var_dump()结果来了解结果如何。这是我用来vardump结果的PHP代码:
foreach($result as $var => $value) {
var_dump($value);
echo "<br />";
}
这就是我得到的:
object(stdClass)#3 (3) {
["Successful"]=> bool(true)
["MessageId"]=> string(0) ""
["MlsMessageText"]=> string(0) ""
}
object(stdClass)#4 (3) {
["RowCount"]=> int(3)
["ColumnCount"]=> int(3)
["Columns"]=> object(stdClass)#5 (1) {
["Column"]=> array(3) {
[0]=> object(stdClass)#6 (2) {
["Name"]=> string(5) "RowID"
["Rows"]=> object(stdClass)#7 (1) {
["string"]=> array(3) {
[0]=> string(5) "12001"
[1]=> string(5) "12002"
[2]=> string(5) "12003" } } }
[1]=> object(stdClass)#8 (2) {
["Name"]=> string(8) "PersonID"
["Rows"]=> object(stdClass)#9 (1) {
["string"]=> array(3) {
[0]=> string(11) "12033310001"
[1]=> string(11) "12033310002"
[2]=> string(11) "12033310003" } } }
[2]=> object(stdClass)#10 (2) {
["Name"]=> string(10) "PersonName"
["Rows"]=> object(stdClass)#11 (1) {
["string"]=> array(3) {
[0]=> string(10) "Jack Jones"
[1]=> string(11) "Jenifer Row"
[2]=> string(12) "Marin Banker" } } }
}
}
}
它是一个相当复杂的答案,我不知道如何用循环解析它。最后,我想得到一个包含数据的表。
任何非常有帮助的帮助:)
答案 0 :(得分:3)
Objects are itteratable。所以你可以用foreach遍历它们。只需使用foreach循环创建递归函数。就像那样:
function loop($input)
{
foreach ($input as $value)
{
if (is_array($value) || is_object($value))
loop($value);
else
{
//store data
echo $value;
}
}
}
答案 1 :(得分:2)
问题是他们将表格转换为column -> row
而不是row -> column
,您可以通过创建新表并反转列和行来实现。
$table = array();
foreach ($result['xxx']->Columns->Column as $colnr => $coldata) {
foreach ($coldata->Rows->string as $rownr => $rowdata) {
$table[$rownr][$coldata->Name] = $rowdata;
}
}
print_r($table);
顺便说一下,$result['xxx']
无效,'xxx'
应该用正确的密钥替换。
答案 2 :(得分:0)
我有类似的问题。我以JSON的形式从代码中获取结果。当我使用json_decode时,我注意到通过var_dump方法,在解码过程中,一些对象是在数组内部创建的。
下面你看到的var_dump是我的var
$result.
如果我想访问&#34; status&#34;来自我的var的数组我使用了下面哪个工作得很好:)
$result[0]->status
我想要那些有查询结果的数据。
array(1) {
[0]=>
object(stdClass)#3 (3) {
["status"]=>
string(9) "Connected"
["message"]=>
string(34) "Connected to database successfully"
["data"]=>
array(1) {
[0]=>
object(stdClass)#2 (10) {
["id"]=>
string(36) "cc569871-6544-11e3-945d-0e184c35292b"
["login_name"]=>
string(22) "tkamran@premierbpo.com"
["login_password"]=>
string(8) "Lead6291"
["notes"]=>
NULL
["created_by"]=>
string(7) "default"
["created_on"]=>
string(19) "2013-12-15 12:52:46"
["last_modified_by"]=>
string(7) "default"
["last_modified_on"]=>
string(19) "2013-12-15 12:52:46"
["is_current"]=>
string(3) "yes"
["is_active"]=>
string(3) "yes"
}
}
}
}