javascript - 将多维数组组合成基于键的字典对象

标签 javascript python arrays list dictionary

我正在尝试根据产品的颜色、尺寸和 Material 为产品创建价格架构。 我目前的实现方式是维护 1 个包含所有选项的 JSON 对象,并尝试使用其选项的所有可能组合生成另一个 JSON 对象。 例如

var productOption = {
  "color":["red","green","yellow"],
  "size":["S","M","L"],
  "material":["leather","linen"]
}

what I want to create something like follow

[
  {
  "red":{
    "S":{
      "leather":{
        "cost":100,"available":true
        }
      }
    }
  },
  {
  "green":{
    "S":{
      "leather":{
        "cost":100,"available":true
        }
      }
    }
  },
  ....

]

所以我可以做类似 price["red"]["S"]["leather"] 的操作来获取小尺寸红色皮革的价格。 有简单的方法吗?在 Javascript 或 Python 中。

编辑:

如果某些产品只有颜色和尺寸或只有颜色怎么办?

var productOption= { color :[...],size:[...]};

编辑 2:

我编写了以下代码来解决我的问题。如果您对我如何改进我的代码有任何建议。请告诉我。

// I am using lodash for those underscore signs.
var processPrice = function(){
  price = {};
  var keys = _.keys(_.pick(priceOption,function(value,key){
    return !_.isEmpty(value);
  }));
  if(keys.length>0){
    genMatrix(keys,[],price);  
  }
};
var genMatrix = function(keys,options,obj){
  var key = keys[0];
  if(keys.length>1){
    var subKeys = _.compact(keys);
      subKeys.shift();
    _.each(priceOption[key],function(opt){
      var subOption = _.compact(options);
      subOption.push(opt.value);
      obj[opt.value]={};
      genMatrix(subKeys,subOption,obj[opt.value]); 
    });
  }else{
    _.each(priceOption[key],function(opt){
      obj[opt.value]={cost: 100, available: true};
    });
  }
};

最佳答案

Python 版本

from itertools import product
result = []
for col, siz, mat in product(*(data["color"], data["size"], data["material"])):
    result.append({col: {siz: {mat: {'available': True, 'cost': 100}}}})
print result

输出

[{'red': {'S': {'leather': {'available': True, 'cost': 100}}}},
 {'red': {'S': {'linen': {'available': True, 'cost': 100}}}},
 {'red': {'M': {'leather': {'available': True, 'cost': 100}}}},
 {'red': {'M': {'linen': {'available': True, 'cost': 100}}}},
 {'red': {'L': {'leather': {'available': True, 'cost': 100}}}},
 {'red': {'L': {'linen': {'available': True, 'cost': 100}}}},
 {'green': {'S': {'leather': {'available': True, 'cost': 100}}}},
 {'green': {'S': {'linen': {'available': True, 'cost': 100}}}},
 {'green': {'M': {'leather': {'available': True, 'cost': 100}}}},
 {'green': {'M': {'linen': {'available': True, 'cost': 100}}}},
 {'green': {'L': {'leather': {'available': True, 'cost': 100}}}},
 {'green': {'L': {'linen': {'available': True, 'cost': 100}}}},
 {'yellow': {'S': {'leather': {'available': True, 'cost': 100}}}},
 {'yellow': {'S': {'linen': {'available': True, 'cost': 100}}}},
 {'yellow': {'M': {'leather': {'available': True, 'cost': 100}}}},
 {'yellow': {'M': {'linen': {'available': True, 'cost': 100}}}},
 {'yellow': {'L': {'leather': {'available': True, 'cost': 100}}}},
 {'yellow': {'L': {'linen': {'available': True, 'cost': 100}}}}]

JavaScript 版本:

var result = [];

for (var i = 0; i < data["color"].length; i += 1) {
    var color = data["color"][i];
    for (var j = 0; j < data["size"].length; j += 1) {
        var size = data["size"][j];
        for (var k = 0; k < data["material"].length; k += 1) {
            var material = data["material"][k], obj = {};
            obj[color] = {};
            obj[color][size] = {};
            obj[color][size][material] = {cost: 100, available: true};
            result.push(obj);
        }
    }
}
console.log(result);

关于javascript - 将多维数组组合成基于键的字典对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23003935/

相关文章:

javascript - jQuery 只能读取一次选择选项?

javascript - 当某些键是数字时,按对象键对数据排序不起作用

python - 将 python 海龟 Canvas 转换为位图时如何保持 Canvas 大小

python - 如何在 OpenCV 或 NumPy 中复制 PyTorch 规范化?

mysql - 从多个表和字符串中选择

javascript - 显示本地存储中的数组值

javascript - "The name does not exist in the current context javascript"+ 窗口位置

javascript - ShareThis issue in IE7 - 无法选择/单击弹出表单下的任何内容

python - 两个 Conv 层之间的 Dropout 和 Batchnormalization

Java ArrayList.contains() 和 add() 方法