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")
答案 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');