我正在尝试创建一个电子表格,允许用户输入最多100行信息,当他们点击提交按钮脚本时,会将该数据输入主数据电子表格。
我编写的脚本可以工作并将数据传输到主数据表,我使用openbyID打开目标表。
问题是无法访问主数据表用户无法打开工作表来添加数据。如果有办法将数据添加到电子表格而无法访问该电子表格,则可以满足我的需求。如果可能,请告诉我。
我再次使用OpenByID打开电子表格,并希望允许用户将数据添加到主电子表格而无需直接访问电子表格。
非常感谢帮助。
如果您有任何疑问,请与我们联系。
谢谢 霍哈尔
我的代码:
Sorry I am not sure how to write my script as web app.
请参阅下面的我的脚本..请您帮我解释一下如何将其更改为Web应用程序?
谢谢
function CopyDataToMaster() {
var inf = SpreadsheetApp.getActiveSpreadsheet();
var inf_sheet = inf.getSheetByName("Info");
var tt_key = inf_sheet.getRange("A4").getValue();
var SiteName = inf_sheet.getRange("A2").getValue();
var d = new Date();
var ss = SpreadsheetApp.getActiveSpreadsheet();
var tt = SpreadsheetApp.openById(tt_key);
var ss_sheet = ss.getSheetByName("Report");
var tt_sheet = tt.getSheetByName("Master-Data-Sheet");
var FilledBy = ss_sheet.getRange("C5").getValue();
var tt_last_row = tt_sheet.getLastRow();
var tt_work_row = tt_last_row+1;
for (var i=1; i<=100 ; i++) {
var dDr = ss_sheet.getRange(i+10, 2);
var dD = dDr.getValue();
if (dD!="") {
var nMr = ss_sheet.getRange(i+10, 3);
var nM = nMr.getValue();
var aMr = ss_sheet.getRange(i+10, 4);
var aM = aMr.getValue();
var bWr = ss_sheet.getRange(i+10, 5);
var bW = bWr.getValue();
var bSr = ss_sheet.getRange(i+10, 6);
var bS = bSr.getValue();
var tDr = ss_sheet.getRange(i+10, 7);
var tD = tDr.getValue();
var mOr = ss_sheet.getRange(i+10, 8);
var mO = mOr.getValue();
var bOr = ss_sheet.getRange(i+10, 9);
var bO = bOr.getValue();
var dCr = ss_sheet.getRange(i+10, 10);
var dC = dCr.getValue();
tt_sheet.insertRowAfter(tt_work_row-1);
tt_sheet.getRange(tt_work_row,1).setValue(Utilities.formatDate(new Date(),+5.5, "MM/dd/yyyy HH:mm:ss"));
tt_sheet.getRange(tt_work_row,2).setValue(SiteName);
tt_sheet.getRange(tt_work_row,3).setValue(FilledBy);
tt_sheet.getRange(tt_work_row,4).setValue(dD);
tt_sheet.getRange(tt_work_row,5).setValue(nM);
tt_sheet.getRange(tt_work_row,6).setValue(aM);
tt_sheet.getRange(tt_work_row,7).setValue(bW);
tt_sheet.getRange(tt_work_row,8).setValue(bS);
tt_sheet.getRange(tt_work_row,9).setValue(tD);
tt_sheet.getRange(tt_work_row,10).setValue(mO);
tt_sheet.getRange(tt_work_row,11).setValue(bO);
tt_sheet.getRange(tt_work_row,12).setValue(dC);
dDr.clearContent();
nMr.clearContent();
aMr.clearContent();
bWr.clearContent();
bSr.clearContent();
tDr.clearContent();
mOr.clearContent();
bOr.clearContent();
dCr.clearContent();
tt_work_row = tt_work_row+1;
}
}
Browser.msgBox("Thank you", "Information has been submitted",Browser.Buttons.OK)
}
答案 0 :(得分:0)
您可以将脚本创建为网络应用,可以访问Google文档和电子表格。如果这样做,您可以设置脚本的权限,以便运行它的用户拥有您的权限而不是他们自己的权限。如果您可以访问主电子表格而不是您的脚本,但您的用户不会。
详情见Google Developers site。向下查看权限和WebApps
的页面答案 1 :(得分:0)
保护一张或两张? - 您可以保护纸张,因此可以编辑某些纸张而其他纸张则不能。您可以控制谁可以编辑哪些工作表。 ...也可以使用数据库公式来拉取数据。减少编写代码的工作量。由于存在所有编辑的历史记录,因此您可以使用此功能查看对工作表所做的所有更改。