繁体   English   中英

将 Firestore 数组打印到 Google 表格

[英]Print Firestore array to Google Sheets

我在 Google Script 中使用 FirestoreApp 来访问我的 Firestore 数据库。 在数据库中,我有一个包含数组的文档,我想将其打印为表格。

这是我的代码:

var allDocuments = firestore.getDocuments("finished/AUG1/2021-3").map(function(doc) {
    return doc.fields;
  });
  const first = allDocuments[0];
  const colum = Object.keys(first);
  const sheet = SpreadsheetApp.getActiveSheet();
  sheet.appendRow(colum);
  allDocuments.forEach(function(doc) {
    const row = colum.map(function(clm) {
      //return doc[clm].toString(); //if documents has array use toString();
      return JSON.stringify(doc[clm], null, 4);
    })
    sheet.appendRow(row);
  })
}

我得到以下回报:

"{
    ""arrayValue"": {
        ""values"": [
            {
                ""stringValue"": ""64MR6""
            },
            {
                ""stringValue"": ""64MR6""
            },
            {
                ""stringValue"": ""64MR6""
            }
        ]
    }
}"

我想打印出下面或彼此相邻的所有“64MR6”,但不知何故,无论我尝试什么,我似乎都无法做到正确。 知道我做错了什么吗?

谢谢!

噗,我们这里是 go:

易于修改逻辑,以防您需要遍历 object 的 object 的 json object ...........

var firestore = FirestoreApp.getFirestore (email, key, projectId);

  var allDocuments = firestore.getDocuments("finished/AUG1/2021-3").map(function(doc) {
    return doc.fields;
  });
  const first = allDocuments[0];
  const colum = Object.keys(first);
  const sheet = SpreadsheetApp.getActiveSheet();
  sheet.appendRow(colum);
  allDocuments.forEach(function(doc) {
    const row = colum.map(function(clm) {
      //return doc[clm].toString(); //if documents has array use toString();
      //return JSON.stringify(doc[clm], null, 4);

      //console.log(console.log(doc[clm]["arrayValue"]["values"][1]).toString());
      for (i=0;i<doc[clm]["arrayValue"]["values"].length;i++)
      {
      for (const [key, value] of Object.entries(doc[clm]["arrayValue"]["values"][i])) {
        //console.log(`${key}: ${value}`);
        console.log(`${value}`);
      }
      }
      
    })
    sheet.appendRow(row);
  })
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM