0

選択した Google カレンダーから選択した日付範囲の新しい Google スプレッドシートにイベント データをエクスポートする小さな Google Apps スクリプトに取り組んでいます。私が抱えている問題の 1 つは、スプレッドシートにコピーされる時間が 3 時間ずれていることです。これを処理し、イベント時間を正しく表示する方法に関する提案はありますか?

これまでの私のコードは次のとおりです:(これは進行中の作業です)

function doGet() {
  var app = UiApp.createApplication();
  var handler = app.createServerHandler("change");
  var picker1 = app.createDatePicker().addValueChangeHandler(handler).setId("picker1");
  var picker2 = app.createDatePicker().addValueChangeHandler(handler).setId("picker2");
  var pickerpanel = app.createHorizontalPanel();
  var panel = app.createVerticalPanel();
  pickerpanel.add(picker1);
  pickerpanel.add(picker2);
  panel.add(pickerpanel);
  var lb = app.createListBox(false).setId('lbCalSelId').setName('lbCalSelect');

  lb.setVisibleItemCount(3);
  var cals = CalendarApp.getAllCalendars();
  for (var i=0; i<cals.length;i++) {
    lb.addItem(cals[i].getName(),cals[i].getId());
  }
  panel.add(lb);

  var button = app.createPushButton().setText("Export").setId("button");
  var handler = app.createServerClickHandler('doExport').addCallbackElement(panel);
  button.addClickHandler(handler);
  panel.add(button);
  app.add(panel);
  return app;  
}

function change(eventInfo) {
  var app = UiApp.getActiveApplication();
  if (eventInfo.parameter.picker1) {
    UserProperties.setProperties({"DateRangeStart":eventInfo.parameter.picker1});
    app.add(app.createLabel("Start date " + eventInfo.parameter.picker1));
  }
  else if (eventInfo.parameter.picker2) {
    UserProperties.setProperties({"DateRangeEnd":eventInfo.parameter.picker2});
    app.add(app.createLabel("End date" + eventInfo.parameter.picker2));
  }

  return app;
}

function doExport(eventInfo) {
  var app = UiApp.getActiveApplication();
  var calId = eventInfo.parameter.lbCalSelect;
  var cal = CalendarApp.getCalendarById(calId);
  var rangeStart = UserProperties.getProperty("DateRangeStart");
  var rangeEnd = UserProperties.getProperty("DateRangeEnd");
  app.add(app.createLabel("The button was clicked!"));
  if (rangeStart && rangeEnd) {
   app.add(app.createLabel("exporting..."));
   var events = cal.getEvents(new Date(rangeStart), new Date(rangeEnd));
   var eventsData = [];
   var headerRow = ['Title','Start Time','End Time','Location','Description'];
   for (var i=0; i < events.length; i++) {
     var eventData = [];
     eventData.push(events[i].getTitle());
     eventData.push(events[i].getStartTime());
     eventData.push(events[i].getEndTime());
     eventData.push(events[i].getLocation());
     eventData.push(events[i].getDescription());
     eventsData.push(eventData);
   }
   var ss = SpreadsheetApp.create("Export of " + cal.getName() + " from " + rangeStart + " to " + rangeEnd);
   var sheet = ss.getSheets()[0];
   var destRange = sheet.getRange(1, 1, events.length, headerRow.length);
   destRange.setValues(eventsData);
  }
  else {
   app.add(app.createLabel("Range not specified."));
  }

  return app;
}
4

1 に答える 1

1

私はそれを考え出した。

スプレッドシートのタイムゾーンをカレンダーと同じタイムゾーンに設定しただけで、うまく機能しました。

ss.setSpreadsheetTimeZone(cal.getTimeZone());
于 2013-02-15T16:00:33.347 に答える