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

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

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

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

Q&A

解決済

2回答

10101閲覧

GASのgetActiveCell()が動作しない

skydalt0n

総合スコア19

Google Apps Script

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

0グッド

0クリップ

投稿2019/05/30 03:35

GoogleAppsScriptの『getActivecell()』について質問です。

昨日まで正常に動作していましたが、今日は正常に動作せず、大変困っています。
GASに何か不具合等が発生しているのでしょうか?

現在、以下の様な状態になっています。

  • 昨日は動作していたgetActivecell()を含めたコードが動かなくなった。
  • 検証用に新規でテストのスプレッドシートとテストスクリプトファイルを作成し、

getActivecell()だけを使用したスクリプトをテストしたが動かなかった。

  • getActivecell()を使用している、過去に作成したスクリプトも動かなくなっていた。
  • web上にあるサンプルも動作させてみましたが、同様に動作しませんでした。

GoogleAppsScript

1//テスト 2function GetActiveCell() { 3 var ss = SpreadsheetApp.getActiveSpreadsheet(); 4 var sheet = ss.getActiveSheet(); 5 6 var range = sheet.getActiveCell(); 7 var row = range.getRow(); 8 Logger.log(row); 9}

正確には、動かないというより「挙動が変」という感じです。

  • getActiveCell().getRow();はセルのrow座標を取得できる。(※)
  • getActiveCell().getColumn();では、セルがどの座標にいても必ず1になる。
  • getActiveCell();だけの場合は、実際にアクティブになっているセル座標に関係なく(1, 1)が返される

という「動いてはいるが原点を取得している」という感じです。(勿論アクティブなセルはA1にはありません)
(※)この文章を書いている間に、getRow()も取得される値が「1」になり、取得できなくなりました。

どうすれば良いでしょうか?

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

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

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

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

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

macaron_xxx

2019/05/30 05:18

私は再現せず、正常に取得できました。
papinianus

2019/05/30 09:09

どうやって実行してます?シートの変更時のトリガーでコメントを編集してたりしませんか?
skydalt0n

2019/05/30 15:20

アドバイスありがとう御座います。 トリガー等は一切設定していません。又、ライブラリなども使用していません。 新規スプレッドシートを作成し、そのメニューから「ツール > スクリプトエディタ」でスクリプトエディタを起動。 上記のコードをコピペで実行しましたが、やはりアクティブセルが何処にあってもgetActiveSheet();を使用すると、スプレッドシートのA1(1, 1)を見に行きます。 シートもスクリプトも新規で作成し、テストのスクリプは1つだけですので、同名関数などで間違える要素はない無いと思われます。 試しに、getRange(2, 4).getValue();などで座標を指定すると、そのセルの値を取得してくれますので、 やはりgetActiveCell();に問題がある気がします。 念の為環境は以下になります windows7 64bit Chromeバージョン: 74.0.3729.169
papinianus

2019/05/30 22:59

情報ありがとうございます。ここは閉じられるので本文に追記なさったほうが多くの人の目に触れます。 また、macaron_xxx様より後に試して同じということはgasに障害があったわけでもなさそうですね。私も検証してみます
papinianus

2019/05/30 23:53

残念ながら当方でも再現させることができませんでした。 思いついた可能性として、何らかの要因で意図せずシート側で範囲選択状態になっているのではないかな、ということを考えました。 ドキュメントにもあるようにgetColumn(), getRow()は範囲の開始列、開始行を取得します。 確認のためにgetLastColumn(), getLastRow()を試してはいただけませんでしょうか もちろん質問者様は特定のセルの話をしているのであって、範囲選択をする意図がないことは理解しています。ただ、Rangeは1セルでも範囲セルでも同じオブジェクトですので、何らかの問題で複数範囲状態であってもgetColumn()だけでは気付けないので、その切り分けのためも含めての確認依頼とご理解いただければと思います。 ドキュメント https://developers.google.com/apps-script/reference/spreadsheet/range#getColumn()
guest

回答2

0

解答ではないですが、下記のコードを試してログをとってください。

javascript

1function q192168() { 2 const sheet = SpreadsheetApp.getActiveSheet(); 3 const setRange = sheet.getRange(2, 4); 4 5 sheet.setActiveRange(setRange); 6 7 const activeCell = sheet.getActiveCell(); 8 9 Logger.log(activeCell.getRow()); 10 Logger.log(activeCell.getColumn()); 11}

これでログが1,1ならgetActiveCellの問題ですね。

投稿2019/05/31 03:55

macaron_xxx

総合スコア3191

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

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

0

自己解決

返信が遅れて申し訳ございません。
getActiveCell();がの挙動が突然元に戻りました。
全く意味が判りません・・・

  • 今回問題があったスクリプトでも、新規で作成したスクリプトでも正常に動きます。

 (もちろん最初に書いたサンプルコードもコピペで動きます。)

  • 過去に作成したgetActiveCell()を使用したスクリプトも正常な動作に戻りました。

複数のPC、複数のブラウザからアクセスしても同様の不具合が発生していたので、環境では無いと思いますが
なんとも気味の悪い解決(?)です。(今度は逆にエラーが起きないので検証出来ない)

調べた所、getActiveCell()は極稀に動かなくなることが有る様です。
twitterでも「動かない」と仰られている方がいました。

一番似ている症状は以下になります。(上から2つ目)
https://issuetracker.google.com/issues/36755274

getActiveCell() method always returns A1 cell, no matter which cell is actually active.
(getActiveCell()メソッドは、どのセルが実際にアクティブであっても、常にA1セルを返します)

バグと報告されています。ただ古いログなのでその様な問題は解決されていると思いますが・・

以上です。
ありがとうございました。

投稿2019/06/03 17:00

編集2019/06/03 17:01
skydalt0n

総合スコア19

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問