3

我有这个 javascript 数组:

[['a', 'x', 1],
 ['a', 'y', 2],
 ['b', 'x', 3],
 ['b', 'z', 4],
 ['c', 'y', 5],
 ['c', 'z', 6]]

我如何将它旋转到类似于下面的第二列('x','y','z')从上面穿过。

[['a', 1, 2, null],
 ['b', 3, null, 4],
 ['c', null, 5, 6]]

编辑:对不起,我不清楚。到目前为止的答案似乎是引用 x、y、z 的静态长度/值。该数组将是动态的,并且可以在第二列中包含任何内容(例如,'t'、'u'、'v'、'w' 而不是 'x'、'y'、'z')。我想我需要先用所有可能组合的空值填充数组,然后推入值。

谢谢..

4

3 回答 3

2

根据 Fabricio 的评论,您可以通过以下方式完成类似的操作:

var result = {};
for(var i=0;i< basearray.length;i++){
    if(!result[basearray[i][0]]){
        result[basearray[i][0]]={};
    }
    result[basearray[i][0]][basearray[i][1]]=basearray[i][2];
}

请注意,这将返回一个对象或哈希图,而不是严格意义上的数组,但数据更有条理,如果您愿意,可以轻松地将其转换为数组。是一个演示(检查您的控制台)。

通过添加此代码:

var count=0;
for(var key in result){
    result[count]=[];
    result[count][0]=key;
    result[count][1]=result[key].x||null;
    result[count][2]=result[key].y||null;
    result[count][3]=result[key].z||null;
    count++;
}

您的结果对象现在可以模拟结构、原始数组和建议的键值对。你可以在这里看到结果:http: //jsfiddle.net/9Lakw/3/

这是result看起来的样子:

{
   "a":{
      "x":1,
      "y":2
   },
   "b":{
      "x":3,
      "z":4
   },
   "c":{
      "y":5,
      "z":6
   },
   "0":[
      "a",
      1,
      2,
      null
   ],
   "1":[
      "b",
      3,
      null,
      4
   ],
   "2":[
      "c",
      null,
      5,
      6
   ]
}
于 2012-10-24T22:26:53.170 回答
1

这就是我的做法,使用null问题中的数组和填充符。这假设给定点的坐标总是连续出现的。

var arr = [['a', 'x', 1],
 ['a', 'y', 2],
 ['b', 'x', 3],
 ['b', 'z', 4],
 ['c', 'y', 5],
 ['c', 'z', 6]];

var aux = {
        x: 1,
        y: 2,
        z: 3
    },
    output = [],
    lastItem,
    currItem;

for (var i = 0; i < arr.length; i++) {
    currItem = arr[i];
    if (currItem[0] !== lastItem) {
        lastItem = currItem[0];
        output.push([lastItem, null, null, null]);
    }
    output[output.length-1][aux[currItem[1]]] = currItem[2];
}
console.log(output); //[["a", 1, 2, null], ["b", 3, null, 4], ["c", null, 5, 6]]

小提琴

于 2012-10-24T22:31:21.777 回答
0

你确定这是你想要的格式吗?似乎更明智的是:

{
    a: {x: 1, y: 2},
    b: {x: 3, z: 4},
    c: {y: 5, z: 6}
}

您可以从中获得:

var results = {};
data.forEach(function(el) {
    var name = el[0];
    var prop = el[1];
    var value = el[2];
    results[name] = results[name] || {};
    results[name][prop] = value;
})
于 2012-10-24T22:37:03.743 回答