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

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

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

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

Google フォーム

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

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

Q&A

解決済

1回答

1756閲覧

【GAS】for文とif文で出力した値の合計値の出し方

Yt182

総合スコア4

Google スプレッドシート

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

Google フォーム

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

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

0グッド

0クリップ

投稿2020/07/11 02:33

前提・実現したいこと

見て頂いてありがとうございます。
初心者による質問ですが、お手柔らかにお願い致します。

Google Apps Scriptで栄養素管理Webアプリを作成しようとしています。
機能は以下です。
①Googleフォームから都度食べたものの品目やカロリーをスプレッドシートへ投入
②毎朝8時に「昨日の摂取カロリーは〇〇、摂取タンパク質量は〇〇g、体重は〇〇kgでした」とLINEでリマインドしてくれる

発生している問題・エラーメッセージ

①は問題なくできました。
②のコードを書いていますが、うまくいきません。

1.スプレッドシート「栄養素記録(回答)」をSpreadsheetオブジェクトとして取得する。
2.そのSpreadsheetオブジェクトの配下にあるシート「フォームの回答 1」をSheetオブジェクトとして取得する。
3.そのSheetオブジェクトの配下にあるA列(タイムスタンプ)が昨日の日付のC列(摂取カロリー)のセルを取得する。
4.取得した値を合計する
5.そのSheetオブジェクトの配下にあるA列(タイムスタンプ)が昨日の日付のD列(摂取タンパク質)のセルを取得する。
6.取得した値を合計する
7.そのSheetオブジェクトの配下にあるA列(タイムスタンプ)が昨日の日付のE列(体重)のセルを取得する。
8.取得した値の最大値を取得する
9.メールで送信する

この流れでコードを書いています。

現時点では↓

function myFunction() { const sheet = SpreadsheetApp.getActiveSheet(); const lastRow = sheet.getLastRow(); const date = new Date(); const today = Utilities.formatDate(date, 'JST', 'yyyy/MM/dd'); const day = date.getDate(); date.setDate(day - 1); const yesterday = Utilities.formatDate(date, 'JST', 'yyyy/MM/dd'); for(let i = 2; i <= lastRow; i++) { var rowDate = Utilities.formatDate(sheet.getRange(i, 1).getValue(), 'JST', 'yyyy/MM/dd'); if (rowDate === yesterday){ console.log(sheet.getRange(i,3).getValue()); } } }

「昨日」を取得する定数yesterdayを定義し、
for関数を用い、2行から下を順番に処理していくようにし、
if関数で「i,1(タイムスタンプ列)」が「定数yesterday」と一致する「i,3(摂取カロリー列)」を出力する。
というコードを手伝って頂き書くことが出来ました。

if関数で出力した"「i,1(タイムスタンプ列)」が「定数yesterday」と一致する「i,3(摂取カロリー列)」"をすべて合計するコードの書き方がわかりません。

どなたかご教授お願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

GAS

1function myFunction() { 2 const sheet = SpreadsheetApp.getActiveSheet(); 3 const lastRow = sheet.getLastRow(); 4 const date = new Date(); 5 const today = Utilities.formatDate(date, 'JST', 'yyyy/MM/dd'); 6 const day = date.getDate(); 7 date.setDate(day - 1); 8 const yesterday = Utilities.formatDate(date, 'JST', 'yyyy/MM/dd'); 9 10 var caloryTotal = 0; 11 for(let i = 2; i <= lastRow; i++) { 12 var rowDate = Utilities.formatDate(sheet.getRange(i, 1).getValue(), 'JST', 'yyyy/MM/dd'); 13 14 if (rowDate === yesterday){ 15 var calory = sheet.getRange(i, 3).getValue(); 16 console.log(`${rowDate}: ${calory}カロリー`); 17 caloryTotal += calory; 18 } 19 } 20 console.log(`total: ${caloryTotal}カロリー`); 21}

投稿2020/07/11 03:54

Daregada

総合スコア11990

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

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

Yt182

2020/07/11 05:37

昨日に引き続きありがとうございました。 一つ一つ調べながら内容を理解しましたのでもう二度と同じ質問はしないかと思います。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問