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

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

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

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

Google Apps Script

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

Q&A

3回答

2999閲覧

スプレッドシートで最終行が追加されたら同じ最終行のG列に関数を挿入したい

ko1

総合スコア23

Google スプレッドシート

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

Google Apps Script

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

0グッド

2クリップ

投稿2021/12/24 05:37

編集2021/12/24 05:37

スプレッドシートで最終行が追加されたら同じ最終行のG列に関数を挿入したい

スプレッドシートで最終行が追加されたら同じ最終行のG列に関数を挿入したいです。
wordpressのcontact form7で送信された問い合わせをスプレッドシートに飛ぶように設定しております。

スプレッドシートの最終行(空白セル)に自動的に追加(A~F)されていきますが、その中でE列に入った数字を参照してG列に結果を表示させたいです。

元から関数を入れていると関数が入っている行以降に送信されたデータが入ってしまう状況です。

GAS、トリガーを使用した方法をお手数ですがご教示お願い致します。

イメージ説明

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

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

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

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

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

guest

回答3

0

  • Contact Form7 での問い合わせを自動でスプレッドシートにまとめるプラグイン「CF7 Google Sheets Connector」を徹底解説! - インターネットビジネスラボ

https://iblab.net/cf7-google-sheets-connector/#2_CF7_Google_Sheets_Connector%E3%81%AE%E3%83%A1%E3%83%AA%E3%83%83%E3%83%88

こういうのを使ってるってことですよね。

"行の追加"という操作をすると、どこの列でもどこかに入力があると、その行は埋まっていると考えられて、関数がある行には入らなくなります。

現実的な解決策として、関数をそのシートに入れずに、集計するためのシートを別に作って、シート参照や IMPORTRANGE を使って、集計シートに Contact Form7 Connecter から送られて来たデータが転記されるようにして、そっちで集計することにする、が良いのではないかと思います。

挿入が起きたら、集計関数を入れるようなマクロを書けば、単一シートで解決できるかもです(そういうの書いてくれる人を探すのは大変だと思うので、現実的な解決にならないと思います)。

投稿2021/12/29 09:26

papinianus

総合スコア12705

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

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

0

G1のセルに
「=ARRAYFORMULA(IFS(A1:A="名前","計算式", A1:A<>"", 目的の関数, "TRUE", ""))」
と入れます。
目的の関数には、データ1とデータ2とデータ3の合算なら「D1:D+E1:E+F1:F」の様に入れます。

投稿2021/12/27 05:45

miygr2021

総合スコア2

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

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

ko1

2021/12/27 07:31

回答ありがとうございます。 下記のようなコードで試してみたのですが、数式はうまくいったのですが、自動で出てくるようにはなりませんでした。ご教示の程お願いします。 =ARRAYFORMULA(IFERROR(INDEX('list'!B:C,MATCH(INDIRECT(ADDRESS(ROW(),COLUMN()-1)),'list'!A:A,-0)),"該当無し")) 左のセルをみて、別シートを参照して該当するデータを表示させる形です。
guest

0

ソースコードを拝見していないため、どこでつまづいているかわかりませんが、、

setFormula()

1

により、スプレッドシートの関数を入力できます。
トリガーの設定ですが、「スプレッドシートの編集時」の設定でいかがでしょうか。
編集されるたび、編集されたシートを取得して、それがフォームの結果用のシートだったら発火、という形です。

繰り返しにはなりますが、詳しいソースコードを拝見しない限りはなんとも、、

投稿2021/12/25 14:05

daltonya

総合スコア109

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

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

ko1

2021/12/27 07:30

ご回答ありがとうございます。 編集時でトリガーを設定してみたのですが、やはり、関数が入っているセルより以降に入ってしまう状況です。 コードは下記のような形になります。 =ARRAYFORMULA(IFERROR(INDEX('list'!B:C,MATCH(INDIRECT(ADDRESS(ROW(),COLUMN()-1)),'list'!A:A,-0)),"該当無し"))
daltonya

2021/12/28 00:44

それはソースコードではなく関数ですね。 contact form7の仕様を詳しくは知りませんが、form入力の際に、情報が入っている最終行を取得して、その一つ次のセルに入力しているのではないでしょうか。 それだと予め関数を入れておくことは叶いませんし、contact form側がGASによって操作しているのなら、こちらがGASのによって新たに関数を入力することもできません。 試せることとしては、 ① 予め関数を全て削除。編集時に、setFormulaにより関数を追加する。 ②contact form7ではなく、Google formを埋め込み、使用する。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問