我正在创建一个带有Node的REST API,它从Azure表存储中读取。
输出类似于以下内容:
[
{
"PartitionKey":{
"$":"Edm.String",
"_":"sdsdsdsd"
},
"RowKey":{
"$":"Edm.String",
"_":"sdsdsdsdsd"
},
"Timestamp":{
"$":"Edm.DateTime",
"_":"2015-08-20T01:56:37.499Z"
},
"Destination":{
"_":"sdsdsdsdsd"
},
"QueryParameters":{
"_":"sdsddsadsadsd"
},
"Referrer":{
"_":"sddsadsadss"
},
"RequestTime":{
"$":"Edm.DateTime",
"_":"sdsddsdsd"
},
"SiteUrl":{
"_":"sdsdsdsdd"
},
".metadata":{
"etag":"W/"datetime'2015-08-20T01:56:37.4999599Z'""
}
}
]
我正在使用lodash,因为我想要转换响应,因此它具有以下内容:
有人可以帮忙吗?
答案 0 :(得分:0)
考虑到您已将json对象分配给raw
对象,
这是在lodash上做到这一点的一种方法。
在处理值之前首先规范化键:
const _ = require('lodash')
const lowKey = _.mapKeys(raw, (v,k) => k.toLowerCase())[0]
const norm = _.mapValues(lowKey, (v)=> {
delete v.$
if(Object.keys(v).length ===1 && v._) return v._;
else return v;
});
console.log(norm)