我有一本字典:
db_dict={'Col1': ['1', '2', '3', '4'], 'Col2': ['2', '4', '6'], ...}
我想制作一个这样的字符串:
var simpleQuery = "col1={'1', '2', '3', '4'}&col2={'2', '4', '6'}"
到目前为止,我已经尝试过这个:
function getdbdict() {
{ %
for key, values in dbdict.items %
}
var col = '{{key}}';
var val = '{{values}}';
var colval = col + '=' + '{' + '"' + val + '"' + '}'; { % endfor %
}
var simpleQuery = colval
我是新手,请帮我这样做。
答案 0 :(得分:1)
这样做:
var db_dict={'Col1': ['1', '2', '3', '4'], 'Col2': ['2', '4', '6']};
var workingArray = []
for (var key in db_dict) {
if (db_dict[key].length > 0)
workingArray.push(key.toLowerCase() + "={'" + db_dict[key].join("','") + "'}");
else
workingArray.push(key.toLowerCase() + "={}");
}
var simpleQuery = workingArray.join("&");
console.log(simpleQuery); // col1={'1','2','3','4'}&col2={'2','4','6'}
你的样本采用了原始对象的键名,并在simpleQuery
中将它们设为小写,所以我也做了同样的事情。显然,如果不需要,您可以删除.toLowerCase()
。
答案 1 :(得分:1)
您可以尝试以下
db_dict={'Col1': ['1', '2', '3', '4'], 'Col2': ['2', '4', '6']};
var str = "";
for(var key in db_dict){
str +=key +"={";
for(var i=0;i<db_dict[key].length; i++){
str += db_dict[key][i];
if(i != db_dict[key].length-1)
str +=",";
}
str+="}";
str+="&";
}
str = str.substring(0, str.length - 1);
您可以在行动here
中看到它我相信它可以被重构,但它只是给你一个想法。