带有 dimple.js 图表的嵌套 JSON 对象数据

Nested JSON object data with dimple.js chart

我需要帮助来展平我的 json 嵌套格式的数据。我已经尝试了一些我在 S/O 中找到的东西,但没有太大帮助。我花了很多时间用静态数据创建我的图表,我不知道我会得到这种格式的数据。任何帮助都感激不尽!我正在使用酒窝垂直堆栈 var

 {
  "head": {
    "vars": [ "Country" , "City" , "County" , "Fiscal_Year" , "Fiscal_Qtr" , "Start_Period" , "End_Period" , "Extract_Date" ,  "AA" , "BB" , "CC" , "DD" , "EE" , "FF" , "GG" , "HH" , "II" , "JJ" , "KK" , "LL" , "MM" , "NN" ]
  } ,
  "results": {
    "bindings": [
      {
        "Country": {  "type": "typed-literal" , "value": "United States" } ,
        "City": {  "type": "typed-literal" , "value": "New York" } ,
        "County": {  "type": "typed-literal" , "value": "Manhattan" } ,
        "Fiscal_Year": {  "type": "typed-literal" , "value": "2014" } ,
        "Fiscal_Qtr": { "type": "typed-literal" , "value": "1" } ,
        "Start_Period": { "type": "typed-literal" , "value": "2014-10-01" } ,
        "End_Period": {  "type": "typed-literal" , "value": "2014-12-31" } ,
        "Extract_Date": {"type": "typed-literal" , "value": "2015-01-01" } ,
        "AA": {  "type": "typed-literal" , "value": "0.549" } ,
        "BB": { "type": "typed-literal" , "value": "0.1526" } ,
        "CC": {  "type": "typed-literal" , "value": "0.0258" } ,
        "DD": { "type": "typed-literal" , "value": "0.047400000000000005" } ,
        "EE": { "type": "typed-literal" , "value": "0.21780000000000002" } ,
        "FF": {"type": "typed-literal" , "value": "0.0074" } ,
        "GG": { "type": "typed-literal" , "value": "0.615" } ,
        "HH": { "type": "typed-literal" , "value": "0.507" } ,
        "II": { "type": "literal" , "value": "--" } ,
        "JJ": {"type": "typed-literal" , "value": "0.113" } ,
        "KK": {  "type": "typed-literal" , "value": "0.026" } ,
        "LL": { "type": "typed-literal" , "value": "0.034" } ,
        "MM": { "type": "typed-literal" , "value": "0.318" } ,
        "NN": { "type": "typed-literal" , "value": "0.002" }
      } 

我正在寻找类似这样的输出:

    [
{"Country": "United States"},
{"City": "New York"},
{"County": "Manhattan"},
{"Fiscal_Year": "2014"},
{"Start_Period": "2014-10-01"},
{"End_Period": "2014-12-32"},
{"Extract_Date": "2015-01-01" },
{"AA": "0.549" },
{"BB": "0.1526" },
{"CC": "0.0258" },
{"DD": "0.047400000000000005" },
{"EE":  "0.21780000000000002" },
{"FF": "0.0074" },
{"GG":  "0.615" },
{"HH":  "0.507" },
{"II":  "--" },
{"JJ":  "0.113" },
{"KK":  "0.026" },
{"LL":  "0.034" },
{"MM":  "0.318" },
{"NN":  "0.002" }
]

Javascript 的 Object.keys() 接受一个对象(例如 {foo: 1, bar: 2})和 returns 该对象的键数组 ["foo", "bar"].

使用它,您可以像这样转换对象:

data.results.bindings.map(function(original) {
  var converted = {};
  Object.keys(original)
    .forEach(function(key) {
      converted[key] = original[key].value;
    });
  return converted;
})

或者,同样的事情可以使用 reduce 来实现。

data.results.bindings.map(function(original) {
  return Object.keys(original)
    .reduce(function(converted, key) {
      converted[key] = original[key].value;
      return converted;
    }, {});
})

除了第二个选项不依赖于定义 var converted 之外,一种方法并没有比另一种方法更多的好处,从而使更多 "inline-ish" 更具可读性(在至少在某些圈子里)。