SimpleDB将结果转换为PHP数组格式



我知道以前有人问过和回答过这个问题,但我是个聪明人,经过几周的断断续续的搜索,我找不到我需要的东西。我想一定有一些简单的方法可以做到这一点。

现有代码:

$response = $sdb->get_attributes('domain','itemname');
$newresponse = $response->body->GetAttributesResult->to_array();
print_r($newresponse);

我得到这个结果:

CFArray Object
(
    [storage:ArrayObject:private] => Array
        (
            [Attribute] => Array
                (
                    [0] => Array
                        (
                            [Name] => tenants
                            [Value] => Sam Smith
                        )
                    [1] => Array
                        (
                            [Name] => tenants
                            [Value] => Janet Jones
                        )
                    [2] => Array
                        (
                            [Name] => tenants
                            [Value] => Willy Wonka
                        )
                    [3] => Array
                        (
                            [Name] => buildingName
                            [Value] => 123 Main St.
                        )
                )
        )
)

我希望这些数据看起来像:

Array
(
   [tenants] => Array
      (
         [0] => Sam Smith
         [1] => Janet Jones
         [2] => Willy Wonka
      )
   [buildingName] => 123 Main St.
)

我需要说明具有一个或多个值的[tenants]。其他变量可以具有也可以不具有单个值。我还必须考虑到[tenants]可能不是按顺序排列的(即[buildingName][2],另一个[tenants][3]。这里显然有一个概念我不理解。我该怎么做?

编辑以处理私有数组注释
如果我将现有代码修改为以下代码:

$response = $sdb->get_attributes('domain','itemname');
$newresponse = $response->body->GetAttributesResult->to_array()->getArrayCopy();
print_r($newresponse);

我得到这个结果:

Array
(
    [Attribute] => Array
        (
            [0] => Array
                (
                    [Name] => tenants
                    [Value] => Sam Smith
                )
            [1] => Array
                (
                    [Name] => tenants
                    [Value] => Janet Jones
                )
            [2] => Array
                (
                    [Name] => tenants
                    [Value] => Willy Wonka
                )
            [3] => Array
                (
                    [Name] => companyname
                    [Value] => 123 Main St.
                )
        )
)

因此,虽然"私人"的提法已经消失,但同样的基本问题也适用。

基于用户2057272答案的最终解决方案

user2053727,你既是一位绅士(或贵妇(,又是一位学者。你的回答几乎完美。我遇到的一个问题是,结果是:

Array
(
    [tenants] => Array
        (
            [0] => Sam Smith
            [1] => Janet Jones
            [2] => Willy Wonka
        )
    [buildingName] => Array
        (
            [0] => 123 Main St.
        )
)

为了将[buildingName]固定为字符串而不是数组(因为只有一个元素(,我将最后的代码修改为:

$response= $sdb->get_attributes('domain','itemname');
$newresponse = $response->body->GetAttributesResult->to_array();
$new = array();  
foreach($newresponse["Attribute"] as $key => $value) 
    {  
    if(!isset($new[$value['Name']])) 
        {  
        $new[$value['Name']] = array();  
        }  
    $new[$value['Name']][] = $value['Value'];  
    }
array_walk($new, $walker = function (&$value, $key) use (&$walker) 
    {
    if (is_array($value)) 
        {
        if (count($value) === 1 && is_string($value[0])) 
            {
            $value = $value[0];
            }
        else 
            {
            array_walk($value, $walker);
            }       
         }   
    }
    );
print_r($new);

感谢janmoesen(将只有一个值的子数组转换为字符串(的array_walk部分。

我现在的结果正是我所需要的:

Array
(
    [tenants] => Array
        (
            [0] => Sam Smith
            [1] => Janet Jones
            [2] => Willy Wonka
        )
    [buildingName] => 123 Main St.
)

谢谢。

$new = array();  
foreach($newresponse["Attribute"] as $key => $value) {  
    if(!isset($new[$value['Name']])) {  
        $new[$value['Name']] = array();  
    }  
    $new[$value['Name']][] = $value['Value'];  
}  
var_dump($new)  

根据需要进行自定义。

相关内容

  • 没有找到相关文章