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

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

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

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

Q&A

解決済

1回答

758閲覧

Google Apps Script 複数シート の変更方法

kuniya0718

総合スコア8

Google Apps Script

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

0グッド

0クリップ

投稿2018/08/28 13:30

前提・実現したいこと

Google Apps Script 初心者です。
Google Spreadsheetで、

ファイル名「TEST」と「TEST2」の2つのファイルがあります。

シート名「シート1」・「シート2」・「シート3」がそれぞれのファイルにあります。

「TEST」と「TEST2」には同じ表があります。

「TEST」と「TEST2」の
シート「シート2」で

「E列」と「F列」の間に1列追加して、
「E1」に項目名を入れたいです。

現状下記のスクリプトでは、最後に開いたシートだけが変更になります。
また、「TEST」内のスクリプトを実行したときには、「TEST2」はもちろん変更ありません。

「TEST」と「TEST2」の
「シート2」のE列とF列の間に1列作り、
その上で、「E1」の値を「追加項目」としたいです。

該当のソースコード

function myFunction() { var spreadsheet = SpreadsheetApp.getActiveSpreadsheet(); var sheet = spreadsheet.getActiveSheet(); var objSpreadsheet = SpreadsheetApp.getActiveSpreadsheet(); var objSheet = objSpreadsheet.getActiveSheet(); objSheet.insertColumnAfter(4); var range = sheet.getRange("E1").setValue("追加項目"); }

試したこと

()の中に、シート名などをいれましたが、

ReferenceError: 「シート2」が定義されていません。

のようになってしまいます。

アドバイス、よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

他のスプレッドシートを操作するときには、
getActiveSpreadsheet()getActiveSheet()を使用せず、
openById(id)(またはopenByUrl(url))やgetSheetByName(name)を使うようにします。

function myFunction() { var sheets = []; sheets.push(SpreadsheetApp.openById("TESTのID").getSheetByName("シート2")); sheets.push(SpreadsheetApp.openById("TEST2のID").getSheetByName("シート2")); for each(var sheet in sheets) { sheet.insertColumnAfter(4); sheet.getRange("E1").setValue("追加項目"); } }

投稿2018/08/29 00:20

macaron_xxx

総合スコア3191

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

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

kuniya0718

2018/08/29 01:56

素晴らしいですね!! 私のここ何日か悩んでいたことがすっきり解決しました。 ありがとうございます!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問