我正在嘗試使用 appscript 從谷歌表格創建一個日歷。我正在使用下面的嘗試并收到錯誤。
這就是我想要做的。我想將 googlesheets 中的所有事件串列創建到日歷中,作業表中的任何進一步更新都應僅在對作業表的任何最近條目/編輯以及該特定事件時更新日歷。
示例:我有來自 googlesheets 行 A2: A15 的事件,我想一次創建所有事件。發布如果我添加新行 A16,它應該為 A16 詳細資訊創建一個日歷事件。此外,如果我編輯 A10 行,那么我在 A10 中的現有日歷應該會更新,而不會向其他日歷事件發送垃圾郵件。
僅用于背景關系:A1 = 標題,B1 = 開始日期和時間,C1 = 結束日期和時間,D1 = 訪客電子郵件。
我試圖在 for 回圈中宣告變數 guest ,但效果不佳。關于如何實作這一點的任何建議或建議。

function create_Events(){
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getSheetByName("Calendar");
var last_row = sheet.getLastRow();
var data = sheet.getRange("A1:E" last_row).getValues();
var cal = CalendarApp.getCalendarById("CALENDARID");
//Logger.log(data);
for(var i = 0;i< data.length;i ){
//index 0 =
var event = CalendarApp.getDefaultCalendar().createEvent(data[i][0],
new Date(data[i][1]),
new Date(data[i][2]),
{guests: data[i][3]});
Logger.log('Event ID: ' event.getId());
}
}
uj5u.com熱心網友回復:
這對我行得通。我添加了一個帶有 id (eventId) 的列,以便將來能夠更新。id 也是遵循流程和防止重復的一個很好的指標。
const myCalend = CalendarApp.getCalendarById("############@gmail.com");
const sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Sheet1');
function createCalendarEvent() {
sheet.getDataRange().getValues().forEach((entry, i) => {
if (entry[0] != '' && entry[4] == '') {
let id = myCalend.createEvent(entry[0], entry[1], entry[2], { guests: entry[3] }).getId();
sheet.getRange( i 1, 5).setValue(id)
}
});
}

uj5u.com熱心網友回復:
嘗試這樣的事情
function create_Events() {
const ss = SpreadsheetApp.getActive();
const sh = ss.getSheetByName("Calendar");
const vs = sh.getRange("A1:E" sh.getLastRow()).getValues();
const cal = CalendarApp.getDefaultCalendar();
vs.forEach((r, i) => {
if (r[0] && r[1] && r[3]) {
cal.createEvent(r[0], new Date(r[1]), new Date(r[2]), { guests: r[3] });
} else {
Logger.log(i);
Logger.log(JSON.stringify(r));
}
});
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/486503.html
