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

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

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

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

Google フォーム

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

Google Apps Script

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Google

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

Q&A

解決済

1回答

1632閲覧

[GAS]今日のデータのみ取得したい

marumaru1

総合スコア1

Google スプレッドシート

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

Google フォーム

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

Google Apps Script

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Google

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

0グッド

1クリップ

投稿2021/09/16 08:17

前提・実現したいこと

Googleフォームにて毎日検温記録を行っており、今日の未回答者だけを抽出するシステムを組むことを試みています。
1枚目のシートがフォームの回答、2枚目のシートが名簿とし、3枚目のシートには2枚目に名前があるのに1枚目に名前のない人、つまり未回答者を取得し反映するようにしています。
ただ、毎日の検温なので前日に回答している場合、1枚目に名前が残り、3枚目に反映されなくなってしまいます。
今日だけのデータを取得し反映する方法をご教示願いたいです。

Googleフォームへの回答時にタイムラインが記録されれるので、それを利用できないかを考えているのですが、上手くいきません。

■■な機能を実装中に以下のエラーメッセージが発生しました。

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

エラーメッセージ

該当のソースコード

function appendRecords() { const ss = SpreadsheetApp.getActiveSpreadsheet(); const memberSheet = ss.getSheetByName("回答者一覧"); const answerSheet = ss.getSheetByName("フォームの回答1"); const noanswerSheet = ss.getSheetByName("未回答者"); //シート[回答者一覧]から全員の名前、[フォームの回答1]から回答済みメンバーの名前を取得 const array01 = memberSheet.getRange(2, 2, memberSheet.getLastRow()-1).getValues().flat(); const array02 = answerSheet.getRange(2, 3, answerSheet.getLastRow()-1).getValues().flat(); const array03 = []; //pushメソッドを用い差分をarray03に代入 for (const num of array01) { if (!array02.includes(num)) { array03.push([num]); } } var i = array03.length; var j = array03[0].length; noanswerSheet.getRange(1,1,i,j).setValues(array03); }

試したこと

下記のように今日のデータだけを抽出できるようなプログラムを試したのですが、どこか間違ているらしく、datenowが空箱の状態のままになってしまいます。

const date = answerSheet.getRange('A:A').getDisplayValues().flat();
const datenow =[];
Logger.log(date);
var d = new Date();
var y = d.getFullYear();
var mon = d.getMonth() + 1;
var d2 = d.getDate();
var today = y+"/"+"0"+mon+"/"+d2;

if (date.includes(today)){
datenow.push([day])
}

補足情報(FW/ツールのバージョンなど)

初心者なのでGoogleで調べて見よう見まねで組んだシステムなので拙いところが多々ありますが、ご教示願えるととても嬉しいです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

試したこと
const date = answerSheet.getRange('A:A').getDisplayValues().flat();

ご提示のコードでは、A列で日付のマッチングを実施されていることから
以下のようなシート構成になっていると想像します。

シート: フォームの回答1
( A列・B列・C列 )

検温日時体温社員ID
9/16 7:5536.11
9/16 8:2236.22
9/16 8:4037.23
9/16 9:0136.14
9/16 9:2236.85
9/17 6:2236.21
9/17 9:0137.03
9/17 10:1036.45

  
シート: 回答者一覧
( A列・B列 )

社員名社員ID
A1
B2
C3
D4
E5
F6
G7

だったとして
本日は2021年9月17日ですから
未検温の社員4名( 2, 4, 6, 7 )を検出できればいいのですよね。

GAS

1function picupEmployee() { 2 const ss = SpreadsheetApp.getActiveSpreadsheet(); 3 const memberSheet = ss.getSheetByName("回答者一覧"); 4 const answerSheet = ss.getSheetByName("フォームの回答1"); 5 6 const members = memberSheet.getRange(2, 2, memberSheet.getLastRow() -1, 1).getValues(); 7 const answers = answerSheet.getRange(2, 1, answerSheet.getLastRow() -1, 3).getValues(); 8 9 const today = Utilities.formatDate(new Date(),'JST','yyyy/MM/dd'); 10 11 const un_medical = members.filter( v => 12 ! answers.find( x => Utilities.formatDate(new Date(x[0]),'JST','yyyy/MM/dd') === today 13 && 14 x[2] === v[0] 15 ) 16 ) 17 .map( r => [today, ...r]); 18 19 console.log(un_medical); 20}

未検温データを未回答者シートへ転記するコードは
ご自身で記述してみましょう。

投稿2021/09/16 17:56

mayu-

総合スコア335

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

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

marumaru1

2021/09/21 06:21

丁寧なご教示ありがとうございます! 図があってとても分かりやすく、無事必要なシステム構築をすることができました! 大変大変助かりました!ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問