use*_*862 3 permissions google-apps-script google-forms
我正在创建一个脚本,从表单中获取信息并将其写入日历.当我在脚本编辑器中运行脚本时,它工作得很好,从电子表格中获取信息并创建日历事件.但是,当我填写格式并提交(提交是触发器)时,我收到一条错误,指出我没有权限调用getActiveForm().我拥有表格和日历.我很欣赏任何想法.
码
function createEvent() {
var calendarToUse = "testing";
var ssUrlToUse ='https://docs.google.com/a/bay.k12.fl.us/spreadsheets
/d/1ZTDQL9G5U7RqbbKQbAfb3ERqFwpSsC3EOQxdD1zdQwA/edit#gid=441997215';
/* Get Canalnder*/
var calen = CalendarApp.getCalendarsByName(calendarToUse);
var cal = calen[0];
Logger.log(cal.getName());
/* get info from responses*/
var mySS
=SpreadsheetApp.openByUrl(ssUrlToUse).getActiveSheet()
Logger.log(mySS.getName());
var values = mySS.getDataRange().getValues();
var response = values[values.length-1];
var i=2;
var desc = response[i];
var loc = response[i+1];
var start = makeGreatDate( response[i+2], response[i+4]);
var end = makeGreatDate(response[i+3],response[i+6]);
var title = response[i+5];
/* populate calendar event*/
var event = cal.createEvent(title, start, end, {
description : desc,
location : loc
});
};
function makeGreatDate(date, time) {
var day = new Date(date);
day.setHours(time.getHours());
day.setMinutes(time.getMinutes());
Logger.log( "The Date is"+ day);
return day;
}
Run Code Online (Sandbox Code Playgroud)
小智 7
我遇到了同样的问题.我的脚本只是将表单响应和格式化为电子邮件.与OP类似,我不会FormApp.getActiveForm()在我的脚本中的任何地方进行一次调用.
添加PropertiesService.getScriptProperties()呼叫后立即启动此权限问题.
虽然不是一个完整的解决方案,但我能够通过添加一行来FormApp.getActiveForm()保存,然后保存我的触发器(再次检查权限)来解决这个问题.我被要求确认Offline Access脚本的权限.
然后我删除了不需要的行,表单工作正常.
| 归档时间: |
|
| 查看次数: |
5468 次 |
| 最近记录: |