我有一張這樣的桌子:
| 國家 | 年 | fx_rate |
|---|---|---|
| ES | 2021 | 1 |
| ES | 2022 | 1 |
| 東南 | 2021 | 9.98 |
| 東南 | 2022 | 10.01 |
我想將它轉換成嵌套的 JSON(可能不是正確的名稱)。
我有這個代碼:
function toJson(data,indexer){
var cols = data[0];
var index = cols.indexOf(indexer);
var jsonData = {};
for (i = 1; i < data.length; i ) {
if (!jsonData.hasOwnProperty(data[i][index])) {
jsonData[data[i][index]] = [];
}
var jsonCandidate = {};
for (j = 0; j < cols.length; j ) {
if (data[i][j] instanceof Date){
jsonCandidate[cols[j]] = Utilities.formatDate(data[i][j], 'Europe/Madrid', 'yyyy-MM-dd');
}else{
jsonCandidate[cols[j]] = data[i][j];
}
}
jsonData[data[i][index]].push(jsonCandidate);
}
return jsonData;
}
data上表在哪里,是indexerjson 的第一級鍵。如果我使用國家作為索引器,那么我會得到這樣的結果:
{"ES="[{year=2022.0,eur=1.0,"country=ES"},{year=2021.0,eur=1.0,"country=ES"},],"SE="[{year=2021.0,eur=9.98,"country=SE"},{year=2022.0,eur=10.01,"country=SE"}}
我想要的結果是:
{"ES="["year="["2021=" {eur=1.0,"country=ES"},"2022=" {eur=1.0,"country=ES"}]],"SE="["year="["2021="{eur=9.98,"country=SE"},{eur=10.01,"country=SE"}]]}
我想要這個的原因是能夠根據國家和年份等動態欄位呼叫我想要的值,所以我可以做類似 jsonData[country][year]['eur'] 的事情并獲得我想要的外匯匯率每個值。
我能想到的最好的是這段代碼:
function toJson3(data,indexer1,indexer2){
var cols = data[0];
var index1 = cols.indexOf(indexer1);
var index2 = cols.indexOf(indexer2);
var jsonData = {};
for (i = 1; i < data.length; i ) {
if (!jsonData.hasOwnProperty(data[i][index1])) {
jsonData[data[i][index1]] = {};
jsonData[data[i][index1]][data[i][index2]] = [];
}
var jsonCandidate = {};
for (j = 0; j < cols.length; j ) {
if (data[i][j] instanceof Date){
jsonCandidate[cols[j]] = Utilities.formatDate(data[i][j], 'Europe/Madrid', 'yyyy-MM-dd');
}else{
jsonCandidate[cols[j]] = data[i][j];
}
}
jsonData[data[i][index1]][data[i][index2]].push(jsonCandidate);
}
return jsonData;
}
但這未能說明無法讀取未定義的屬性“推送”..
在此先感謝您的幫助
uj5u.com熱心網友回復:
你的 JSON 看起來不太好。可能你想要這樣的東西:
function myFunction() {
var sheet = SpreadsheetApp.getActiveSheet();
var range = sheet.getDataRange();
var [header, ...data] = range.getValues();
var obj = {};
while (data.length) {
var [country, year, rate] = data.shift();
try {
obj[country][year] = {'eur': rate, 'country': country};
} catch(e) {
var y = {};
y[year] = {'eur': rate, 'country': country};
obj[country] = y;
}
}
console.log(obj);
console.log(obj['ES']['2021'].eur);
console.log(obj['SE']['2022'].eur);
}
床單:

輸出:
{ ES:
{ '2021': { eur: 1, country: 'ES' },
'2022': { eur: 1, country: 'ES' } },
SE:
{ '2021': { eur: 9.98, country: 'SE' },
'2022': { eur: 10.01, country: 'SE' } }
}
1
10.01
而且可能您畢竟不需要屬性“國家”。
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/447623.html
