如何从对象创建可用数组

时间:2019-04-22 19:23:30

标签: php joomla

我有一个使用loadRow()从Joomla中的数据库查询返回的JSON数组。
我们将自定义字段用于一些精美的页面内容。

我需要这条记录中的文本/值对,位于不同的可用数组中。

我尝试了爆炸,array_map,许多不同的操作,但是我正在为正确的代码组合而苦苦挣扎。

这就是对象的样子。

Array ( [0] =>   
    {"options":  
        {"options0":  
            {"name":"soph","value":"School of Public Health"},  
        "options1":  
            {"name":"son","value":"School of Nursing"},  
        "options2":  
            {"name":"sohp","value":"School of Health Professions"}  
        }
    }
)

我需要的是这样的

Array (
    [0] => {"name":"soph","value":"School of Public Health"},  
    [1] => {"name":"son","value":"School of Nursing"},  
    [2] => {"name":"sohp","value":"School of Health Professions"}
)

2 个答案:

答案 0 :(得分:1)

好像您将其作为JSON数据存储在数据库中。这样的事情应该起作用:

$row = json_decode($arr[0], true)['options'];
$optionList = [];
foreach($row as $option => $options)
{
   array_push($optionList, [
      'name' => $options['name'],
      'value' => $options['value']
   ]);
}

将新数据放入$optionList

答案 1 :(得分:0)

您的问题对您的需求有些含糊。
我认为那是因为您不知道要问什么问题。

如果我是你,我相信这就是我想要的。
解码数组,并使用数组列对数组进行展平,并使其具有“名称”,键和“值”值。

这样,您可以将数组用作下面代码中的回显线。

$collegeparams = '{"options":  
        {"options0":  
            {"name":"soph","value":"School of Public Health"},  
        "options1":  
            {"name":"son","value":"School of Nursing"},  
        "options2":  
            {"name":"sohp","value":"School of Health Professions"}  
        }
    }';

$arr = array_column(json_decode($collegeparams[0], true)['options'], "value", "name");
var_dump($arr);

echo $arr['sohp'];

以上输出:

array(3) {
  ["soph"]=>
  string(23) "School of Public Health"
  ["son"]=>
  string(17) "School of Nursing"
  ["sohp"]=>
  string(28) "School of Health Professions"
}
School of Health Professions

https://3v4l.org/3MdIN