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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Google Apps Script

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

Q&A

解決済

1回答

330閲覧

スプレッドシートへ変数を用いて数値を出力したい

osntkktd

総合スコア11

Google Apps Script

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

0グッド

0クリップ

投稿2019/06/18 10:23

i行目のA列へ、E列・C列のi行目の数値(日付のシリアル値とIDの様なもの)を結合させたものを出力したいのですが、式の展開ができません。

下記コードで実行すると=CONCATENATE('E'+'+ i +'),('C'+' + i + ')
となってなってしまいます。

何卒ご教示お願いいたします。

該当のソースコード

for(var i = 2; i <= lastRow; i++) { sheet1.getRange(i,1).setFormula("CONCATENATE('E'+'+ i +'),('C'+' + i + ')");

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

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

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

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

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

papinianus

2019/06/18 10:46

根本的なやりたいことをかいてください
guest

回答1

0

ベストアンサー

そもそもスプレッドシート上でセルのコピーを実行したほうが早いと思いますが、なにか事情があるんでしょうか…。


まず、完成形から考えましょう。 i == 2 のときは

=CONCATENATE(E2, C2)

となって欲しいんですよね?
変数化したいのは 2 の部分なのですから、

"CONCATENATE(E" + 2 + ", C" + 2 + ")"

こんなふうに文字列としては分解できるはずです。
あとは i を使うだけですね。

投稿2019/06/18 10:41

mather

総合スコア6753

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

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

osntkktd

2019/06/18 10:52

ご回答ありがとうございました。お陰様で実行出来ました。 googleフォームと連携させようとしているため、スプレッドシート上でのコピーが上手くいきませんでした。
mather

2019/06/18 10:57

フォームで自動入力される部分を置き換えるのですか…。 それよりは元のスプレッドシートはフォームからの入力のみに限定して、別のスプレッドシートから参照するほうが入力したデータがそのまま記録できるので、もし別の形式で値を変換したいときなどにも使いやすくなると思います。
osntkktd

2019/06/18 23:31

フォームから自動入力された際に、スプレッドシートから参照しようとすると、フォームが送信された際の行が増えることに対応出来なかったので…。 アドバイス頂いた方法が本筋かとは思っているのですが、スクリプトで値を拾う事にいたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問