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

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

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

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

JavaScript

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

Q&A

解決済

3回答

10794閲覧

スプレッドシートで特定範囲内に指定文字があるか調べたい

xu0124

総合スコア31

Google Apps Script

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

JavaScript

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

0グッド

0クリップ

投稿2019/08/26 14:50

ABC
はずれはずれはずれ
はずれはずれはずれ
はずれはずれあたり

GASで指定範囲の値を取得すると

sheet.getRange("A1:C3").getValues()
[[はずれ, はずれ, はずれ], [はずれ, はずれ, はずれ], [はずれ, はずれ, あたり]]

というように2次元配列でセルの値が取得されるます。

一応1次元配列に直して指定文字があるか調べることはなんとかできたのですが
もう少しスマートな検索方法はありますでしょうか?

function myFunction() { var sheet = SpreadsheetApp.getActiveSheet(); var data = sheet.getRange("A1:C3").getValues(); Logger.log(data); // [[はずれ, はずれ, はずれ], [はずれ, はずれ, はずれ], [はずれ, はずれ, あたり]] var ary = Array.prototype.concat.apply([],data); for (var i=0; i<ary.length; i++){ if (ary[i] === "あたり") { Logger.log("存在します!"); } } }

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

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

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

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

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

guest

回答3

0

ベストアンサー

別の案として次のような方法はいかがでしょうか。この案では、TextFinderを使用して直接検索します。

スクリプト

javascript

1function myFunction() { 2 var sheet = SpreadsheetApp.getActiveSheet(); 3 if (sheet.getRange("A1:C3").createTextFinder("あたり").findNext()) { 4 Logger.log("存在します!"); 5 } 6}

参考

投稿2019/08/26 22:09

kisojin

総合スコア899

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

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

xu0124

2019/08/27 13:21

TextFinderで文字列を検索できるのですね!!!これはわかりやすいです!!
yasutomi

2019/08/28 12:41

ちなみに1つあるか見るだけなら .findNext()は必要ないです。
kisojin

2019/08/28 22:45

@xu0124 ご返事ありがとうございます。無事解決できたとのことで安心しました。 @yasutomi コメントありがとうございます。「ちなみに1つあるか見るだけなら.findNext()は必要ないです。」について、あまりよく理解できておりません。この場合、どのように変更すると良いのでしょうか。
yasutomi

2019/08/29 11:01

このように変更します。 if (sheet.getRange("A1:C3").createTextFinder("あたり")) { Logger.log("存在します!"); }
kisojin

2019/08/29 22:53

ご返事有難うございます。この場合、"あたり"の有無にかかわらず'sheet.getRange("A1:C3").createTextFinder("あたり")'はオブジェクトを返すため、この場合trueになります。おそらくそちらで確認済みの結果だと思われますのでこちらの方法が悪いのかもしれません。もしもそちらの環境でご提案いただいたスクリプトで"A1:C3"に"あたり"が存在しない場合に、'sheet.getRange("A1:C3").createTextFinder("あたり")'がfalseになるようですと、それを再現する方法をお教えいただけないでしょうか。
yasutomi

2019/08/31 05:01

いえ、私の確認方法に問題がありました。 「.findNext()」は必須ですね。
kisojin

2019/09/01 22:58

ご返事有難うございます。そうでしたか。了解しました。findNext()以外ですと、findAll()で配列の長さが0の場合も検索結果は無しとして使用することもできそうです。いろいろな方法があると思います。
guest

0

filterを使って二次元配列ごと走破するのはどうでしょうか?

Javascript

1function myFunction() { 2 var sheet = SpreadsheetApp.getActiveSheet(); 3 var data = sheet.getRange("A1:C3").getValues(); 4 var target = data.filter(function(val){ 5 if(val.indexOf('あたり') !== -1){ 6 return val 7 } 8 }) 9 10 if(target){ 11 Logger.log('existed') 12 } 13 14} 15

投稿2019/08/26 16:51

fiile

総合スコア16

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

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

xu0124

2019/08/27 13:16

array.filter(callback [,that]); 勉強になります!ありがとうございます!!
guest

0

someを使用する

js

1function myFunction() { 2 var sheet = SpreadsheetApp.getActiveSheet(); 3 var data = sheet.getRange("A1:C3").getValues(); 4 var isAtari = String(data).split(',').some(function(v) { 5 return v === 'あたり'; 6 }); 7 if (isAtari) { 8 Logger.log("存在します!"); 9 } 10}

投稿2019/08/26 15:15

yasutomi

総合スコア2937

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

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

xu0124

2019/08/27 13:18

array.some(callback); 即回答ありがとうございます!!! これは処理負荷がすくなそうですね!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問