GAS - 根据GForm输入选择(获取)电子表格

时间:2017-05-22 13:42:34

标签: google-apps-script google-sheets google-docs mailmerge

Stack Overflow中的第一个问题。 我有一张包含4张单独纸张的Google电子表格。

Sheet1是来自GForm的回复。 Sheet2,3,4有相同的数据,但有3种语言英语,泰米尔语,印地语和英语,泰米尔语,印地语。

目前,Script从Sheet1获取单元格值日期,匹配Tamil表格中的数据,邮件与正确语言Tamil GDoc合并并通过电子邮件发送。

现在,我无法弄清楚如何使脚本选择不同的语言Gsheet,其中一个是3,取决于Form输入中的evalues4,它是一个单选按钮。

有人可以帮我解决一下吗? 选择合适的语言 Gsheet使用ss.getSheetByName和 GDoc使用DriveApp.getFileById 基于表格回复评估4。

如果我只按名称/ sheetID / DocID输入一种语言,这是代码并且工作正常。

//Get information from the form and set as variables 
function onFormSubmit(e) 
{ 
var Time = e.values[0];
var email = e.values[1];
var fog = e.values[2];
var mog = e.values[3];
var lang = e.values[4];
var do_date = e.values[5];

//Match chosen date from data sheet & get Row Number
function findInColumn() {
var data = do_date;
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet1 = ss.getSheetByName("Tamil");
var range = sheet1.getRange(1,1,sheet1.getLastRow(),1);
var values= range.getValues();
var row = 0;
   while ( values[row] && values[row][0] !== data ) {
    row++;
  }
    if (values[row][0] === data) 
    return row+1;
  else 
    return -1;
}  

//Use above Row number to load in Range, get values, assign to variable cells
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet3 = ss.getSheetByName("Tamil");
// Get range of cells in All columns and All rows with entries
var dataRange = sheet3.getRange(findInColumn(), 1, 1, sheet3.getLastColumn());
// Get entries for each row in the Range.
var data = dataRange.getValues();
 // Set each value to a unique variable
  for (i in data) {
    var cell = data[i];

// Get document template, copy it as a new doc with Name and email, and save the id
var copyId = DriveApp.getFileById("1Nxxxxxxxxxxxxxx2k")

2 个答案:

答案 0 :(得分:1)

抱歉,完全忘了我在这里问了这个问题。我在同一个周末解决了它,使用了If - else [注意:而不是var ss我使用了var ssn,而不是var sheet3我在重写中使用了var tocopyID]

    //Use above Row number to load in Range, get values, assign to variable cells
 var ss = SpreadsheetApp.getActiveSpreadsheet();
  if (lang === "Tamil"){ 
    var ssn = ss.getSheetByName("Tamil");
    var tocopyId = DriveApp.getFileById("1NxxxxTamil");
  }
  else if (lang === "Hindi"){ 
   var ssn = ss.getSheetByName("Hindi"); 
   var tocopyId = DriveApp.getFileById("Hindi");
  }
  else if (lang === "English"){ 
   var ssn = ss.getSheetByName("English"); 
   var tocopyId = DriveApp.getFileById("1NxxxxEnglish");
  }

答案 1 :(得分:0)

您可以使用lang变量来获取正确的工作表,因为它们具有相同的名称。喜欢:

var sheet1 = ss.getSheetByName(lang); // where lang = "Tamil" for example

要使用正确的模板,您可以使用Properties存储模板的ID,如:

var templateId = PropertiesService.getScriptProperties().getProperty(lang); // where lang = "Tamil" for example
var copyId = DriveApp.getFileById(templateId);

您可以使用所需的语言名称设置属性。您可以使用代码设置它们:

PropertiesService.getScriptProperties().setProperty('Tamil', '1Nxxxxxxxxxxxxxx2k');