質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google フォーム

Google フォームは、 Google社が提供しているアンケートフォーム作成および集計ができる無料のツール。Googleアカウントがあれば利用が可能です。集計データは、スプレッドシートに収集され、データ分析もできます。

Google カレンダー

Google カレンダーは、Google社が提供する無料のスケジュール管理ツールです。パソコンやスマートフォン、タブレットなどからアクセスし、スケジュールの追加・変更が可能。Googleアカウントがあれば誰でも使用できます。

Q&A

解決済

1回答

1080閲覧

GAS if文を利用したスケジュール追加方法

naokitchi

総合スコア3

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google フォーム

Google フォームは、 Google社が提供しているアンケートフォーム作成および集計ができる無料のツール。Googleアカウントがあれば利用が可能です。集計データは、スプレッドシートに収集され、データ分析もできます。

Google カレンダー

Google カレンダーは、Google社が提供する無料のスケジュール管理ツールです。パソコンやスマートフォン、タブレットなどからアクセスし、スケジュールの追加・変更が可能。Googleアカウントがあれば誰でも使用できます。

0グッド

0クリップ

投稿2020/07/23 05:50

フォームスプレットシートカレンダーへ情報を載せようと考えています。

イメージ説明

statusと書かれているセルが "済"でないものはカレンダーに乗せようと考えているのですが
イメージ通りの動きができずにいる状態です。

ソースコード

function createEventFromSheet() {
// シートを選択
var sheet = SpreadsheetApp.getActiveSheet();
//カレンダーIDでカレンダーを取得
var myCal = CalendarApp.getCalendarById('c_4u9s8b027isnf71jqnkeden8ho@.google.com');
// 行を選択
for(var i = 3; i <= sheet.getLastRow(); i++) {
// セルの値を取得
var status = sheet.getRange(i, 1).getValue().toString();
var start = sheet.getRange(i, 2).getValue().toString();
var end = sheet.getRange(i, 3).getValue().toString();
var title = sheet.getRange(i, 4).getDisplayValue().toString();

if(status.length <= 0) {
break;
}

// 開始と終了の日時を取得
var startTime = new Date(start);
var endTime = new Date(end);

//無事に予定が作成されたら「済」にする
sheet.getRange(topRow + i, 2).setValue("済");
// カレンダーにイベントを追加
myCal.createEvent(title, startTime, endTime);
}
}

プログラミングをしたことがなく見よう見まねでやった結果このざまです。。
がっつりコードなど変えていただいても結構なのでどなたかアドバイスいただけないでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

GAS

1function createEventFromSheet() { 2 // 自分のカレンダーIDに置き換え 3 var myCal = CalendarApp.getCalendarById('xxxxxxxxxxxx@group.calendar.google.com'); 4 5 var sheet = SpreadsheetApp.getActiveSheet(); 6 var dat = sheet.getDataRange().getValues(); 7 8 for(var i = 1; i < dat.length; i++) { 9 if (dat[i][1] != "") { 10 continue; 11 } 12 var title = dat[i][4]; 13 var startDate = new Date(dat[i][2]); 14 var endDate = new Date(dat[i][3]); 15 var options = { 16 description: "" + dat[i][5] + "\n" + dat[i][6], 17 } 18 19 var myEvent = myCal.createEvent(title , startDate , endDate, options); 20 //var eventId = myEvent.getId(); 21 //dat[i][0]= eventId; 22 dat[i][1] = "済"; 23 } 24 sheet.getRange(1, 1, dat.length, dat[0].length).setValues(dat); 25}

投稿2020/07/23 06:28

編集2020/07/23 07:08
Daregada

総合スコア11990

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

naokitchi

2020/07/23 06:59

ご丁寧にコードまで書いていただいてありがとうございます! 実行した結果 statusの部分に"済"が表示されない状態となっています。。 //var eventId = myEvent.getId(); //dat[i][0]= eventId; この部分はコメントアウトしないままで動作するでしょうか? // メールアドレス(dat[i][6]はどう扱うのか不明 この部分も「5」と同様にdescriptionに追加したいと考えています。 大変申し訳ないのですが、こちらに対するアドバイスをしていただいてもいいでしょうか?
Daregada

2020/07/23 07:05

ああ、A1に何か適当な見出しの文字列を入れてから試してもらえますか。 こちらで実験している表ではA1に見出しを書いていたので、getDataRangeの範囲がずれてしまっています。 コメントの部分は、「後でカレンダーの予定をプログラムで操作するときに必要になるイベントID」を空いているA列に入れるもので、そういうことをしたいのでなければコメントのままでOKです。 メールアドレスを追加するのは、回答を書き替えておきます。
naokitchi

2020/07/23 07:57

丁寧なご回答していただいてありがとうございます。。 もう一つ聞きたいことがあるのですが、今の状態ですと予約内容が同じであれば重複してしまうと思うのですが、上記のコードで重複した際に登録をすることができないといった実装を実現することは可能でしょうか? お手数をおかけしてしまい、申し訳ないのですが解決策があればご教授いただきたいです。。
Daregada

2020/07/23 08:11

質問と異なる仕様を後から追加しないでください。私はあなたのサポート担当ではありません。有料のサービスをどなたかと契約してください。
naokitchi

2020/07/23 08:31

失礼いたしました。 今回ご丁寧に対応してくださりありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問