preg_replace删除数组周围的[]

时间:2014-03-09 23:17:31

标签: php arrays preg-replace json

我目前有一个如下所示的数组:

    [[{"name":"Shirt","data":[1,1,5,5,1,10000]},{"name":"Skittles","data":[1,9,1,1]}]]

我正在使用:

        preg_replace('/"([^"]+)"\s*:\s*/', '$1:',json_encode($results));

创建一个看起来像这样的数组:

    [{"name":"Shirt","data":[1,1,5,5,1,10000]},{"name":"Skittles","data":[1,9,1,1]}]

然而,我似乎无法摆脱额外的括号。

我的模特:

    function get_data()
   {
$this->db->select('ItemName, QuantitySold');
$query = $this->db->get('transactions');

$results = array();

foreach ($query->result_array() as $row)
{
    if(!isset($results[$row['ItemName']]))
        $results[$row['ItemName']] = array('name' => $row['ItemName'], 'data' => array());
    $results[$row['ItemName']]['data'][] = $row['QuantitySold'];
}

//Rekey arrays so they aren't associative
$results = array_values($results);
return $results;

}

我的控制器:

    function test()
{
    $this->load->model('data');
    $series_data[] = $this->data->get_data();
    $data['series_data'] = json_encode($series_data, JSON_NUMERIC_CHECK);
    preg_replace('/"([^"]+)"\s*:\s*/', '$1:',json_encode($series_data));
    $this->load->view('chart', $data);
}
提前谢谢。

2 个答案:

答案 0 :(得分:3)

为什么要使用preg_replace ....这只是json编码的数据:

$string = '[[{"name":"Shirt","data":[1,1,5,5,1,10000]},{"name":"Skittles","data":[1,9,1,1]}]]';
var_dump(
    json_encode(
        json_decode($string)[0]
    )
);

答案 1 :(得分:0)

如果您只想删除第一个和最后一个括号,可以使用:

$str = '[[{"name":"Shirt","data":[1,1,5,5,1,10000]},{"name":"Skittles","data":[1,9,1,1]}]]';
$str = preg_replace('/^\[/','',$str);
$str = preg_replace('/\]$/','',$str);
echo $str;

结果

[{"name":"Shirt","data":[1,1,5,5,1,10000]},{"name":"Skittles","data":[1,9,1,1]}]

它会在开头搜索[,在结尾搜索]并删除它们。