如何将JSON输出格式化为所需的格式

时间:2016-11-02 18:56:50

标签: php arrays json wordpress

我正在尝试为WordPress JSON API插件创建一个自定义控制器,到目前为止一切正常,除了我所拥有的JSON数据格式不正确。

这是我目前的JSON输出:

{
  "status": "ok",
  "all_tags": {
    "tag-1": {
      "term_name": "Tag 1",
      "category_details": {
        "0": {
          "category_ID": 8,
          "category_name": "category 1",
          "category_count": 2
        },
        "2": {
          "category_ID": 13,
          "category_name": "category 2",
          "category_count": 1
        }
      }
    },
    "tag-2": {
      "term_name": "Tag 2",
      "category_details": [
        {
          "category_ID": 8,
          "category_name": "category 1",
          "category_count": 2
        }
      ]
    }
  }
}

但是,为了解析数据,我必须具有特定格式的json数据。正确的格式应该是这样的:

{
  "status": "ok",
  "all_tags": [
    {
      "id": 1,
      "term_name": "Tag 1",
      "category_details": [
        {
          "id": 2,
          "category_ID": 8,
          "category_name": "category 1",
          "category_count": 2
        },
        {
          "id": 3,
          "category_ID": 13,
          "category_name": "category 2",
          "category_count": 1
        }
      ]
    },
    {
      "id": 2,
      "term_name": "Tag 2",
      "category_details": [
        {
          "id": 2,
          "category_ID": 8,
          "category_name": "category 1",
          "category_count": 2
        }
      ]
    }
  ]
}

这就是我为json创建数组的方法:

<?php
...
$cats_all     = array(); // the array
if (!isset($cats_all[$custom_term->slug])) {

    // create the array

    $cats_all[$custom_term->slug] = array(
        'term_name' => $custom_term->name,
        'category_details' => array(
            array(
                'category_ID' => $categories[0]->term_id,
                'category_name' => $categories[0]->name,
                'category_count' => $mycats[0]->category_count
            )
        )
    );
} else {
    $cats_all[$custom_term->slug]['category_details'][] = array(
        'category_ID' => $categories[0]->term_id,
        'category_name' => $categories[0]->name,
        'category_count' => $mycats[0]->category_count
    );
}
...
// remove duplicates 
$input = $this->super_unique( $cats_all );
// return the array for json output by the plugin
return array(
    'all_tags' => $input,
);

任何帮助将不胜感激。整个控制器也可以是viewed here

2 个答案:

答案 0 :(得分:1)

您需要完成两件事:

  1. all_tags值必须是顺序数组,而不是关联数组。这可以通过在最后一个语句中取array_values来实现:

    return array(
        'all_tags' => array_values($input)
    );
    
  2. category_details值必须是顺序数组,而不是关联数组。这个更棘手,因为你实际上 将它们创建为顺序数组,但函数super_unique有时会将它们变成关联数组,当它消除时至少一个重复。我建议通过添加两个语句来修复函数super_unique

    $result = array_map( 'unserialize', array_unique( array_map( 'serialize', $array ) ) );
    

    要得到这个:

    $is_seq = end(array_keys($array)) == count($array)-1;
    $result = array_map( 'unserialize', array_unique( array_map( 'serialize', $array ) ) );
    if ($is_seq) $result = array_values($result);
    

    如果您在end上收到错误,那么您可以将其用于该行:

    end($array); $is_seq = key($array) == count($array)-1;
    

    $is_seq变量检查$array是否是连续的,如果是,则在删除重复项后调用array_values,它总是返回一个顺序数组。

答案 1 :(得分:0)

我认为这里的问题是:

home

如果你想让一个数组成为一个json编码数组,索引必须是数字和相关的(0,1,2,3 ...)

可能在使用$ this-&gt; super_unique($ cats_all)之后,或在此函数内部,您应该在每个已重新编制索引的数组上调用array_values;它将数组的值重置为0,1,......等...并且在编码时,它将是一个数组,而不是一个对象。

一般来说,在使用array_filter(...)正确重新索引数组之后使用$ array = array_values($ array)是个好习惯,在其他地方,你可以得到像0,2,7这样的索引......等...

如果您需要更多详细信息,请与我们联系