簡體   English   中英

如何在Google Apps腳本中為數組編制索引?

[英]How to index array's in Google Apps Script?

我當時在從事這個項目,我想創建一個顯示特定列元素的函數。

現在使用javascript,我可以使用

Array[i]

但是由於某種原因,這似乎不適用於Google Spreadsheets。

 var MyFunction(A) {
 return A[1];
 }

此功能對我沒有任何幫助。

EDIt:我解決了。 我將此循環與某種雙索引一起使用:

for (var i=0; i < 37; i++) {
if (A[0][i] < max && A[0][i] != 0) {
var max = A[0][i];
};
};

如果我在電子表格中選擇行向量,則A [0] [0]是第一個元素。 例如,如果我選擇A2:A5作為A,則A [0] [0]將為我提供單元格A2的值! 謝謝您的幫助!

嘗試以下方法:

var MyFunction(A) {
 return A[0];
 }

我在這里所做的假設是您正在嘗試返回索引中的第一個元素。 在javascript中,數組索引從0開始而不是從1開始。

那樣行不通。 您必須首先允許訪問電子表格,然后通過openById告訴Apps腳本您正在使用哪個電子表格。 之后,您現在可以訪問數據。 這是適合您的簡單代碼段。 我正在使用獨立模式。 也許還有其他方法可以做到這一點。

我們將訪問此工作表。 我已經包含了索引號,因此您可以輕松理解:

在此處輸入圖片說明

然后,我們創建一個名為fetchValue的函數,該函數接受2個參數-行和列。

我們執行main函數,該函數調用fetchValue

function main(){
   Logger.log("the value returned was "+ fetchValue(1,1) ); //returns las vegas
}

function fetchValue(row,col) {
  var sheet = SpreadsheetApp.openById("SPREADSHEET_ID_HERE");
  var data = sheet.getDataRange().getValues();

   return data[row][col];
}

然后,如果日志返回的索引為las vegas ,則值為1,1,我們將對其進行查看。

在此處輸入圖片說明

確保傳遞給fetchValue的行和列在范圍內,否則它將返回錯誤。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM