前回
Googleシート YouTubeの関連動画を表示させない方法
NGワードを見つける
複数のNGワードを 見つける
- セル内に含まれるNGワードを判別できるようになります。
- GASのカスタム関数の効果的な使い方がわかります。
- 特定のシートから値を読み込むことができます。
ご質問
S T チャンネル登録期間: 3 週間 • 8 時間前 こんにちは。以下を実現するために最もシンプルな関数を作りたいのですがどうすればいいでしょうか? ・あるセルの文章の中に特定の文字列が含まれる場合、“NGワード”とすぐ近くの別のセルに返したい。 ・特定の文字列というのは、1つではなく多数あります。できればリストを参照する形にしたいです。 例) 特定のワードリスト:○にたい、○ぬ、辛い A1セルの文章:毎晩私は○にたいと思う A2セルの文章:たかしくんは楽しい ⇓ この場合、A1セルにはNGワードリストにある「○にたい」が含まれている判定となるので、どこかのセルに「NGワードあり」といった感じで何か値を返したいです。 A2セルには含まれていないので、NAなどを返したいです。 COUNTIFSでちょっと頑張ろうとしたのですが、文字列を関数内に””で囲って繰り返し並べる長い数式になってしまい、もう少しスプレッドシートで効率的にできないかと思った次第です。 宜しくお願い致します。
動画はこちら
スクリプト
/** * NGワードが含まれているかチェックする。 * 「NGワード」シートにあるNGワードが含まれているかチェックする。 * @param {string} word チェックする文字列。 * @return {boolen} true:NGワードあり false:NGワードなし * @customfunction */ function JUDGNGWORD( word ) { var app = SpreadsheetApp; var ss = app.getActiveSpreadsheet().getSheetByName("NGワード"); var lr = ss.getLastRow(); for( var i=2 ; i <= lr ;i++){ var ckword = ss.getRange(i, 1).getValue(); if(word.indexOf(ckword) >= 0 ){ return(true);//NGワードが見つかった } } return(false);//NGワードなし }
さらに
NGワードを表示させる
上記動画に対してご質問をいただきました。
というわけでやっていきます。
シート
スクリプト
/** * NGワードが含まれているかチェックする。 * 「NGワード」シートにあるNGワードが含まれているかチェックする。 * @param {string} word チェックする文字列。 * @return {number} number:NGワードの位置(行) false:NGワードなし * @customfunction */ function JUDGENGWORD( word ) { var app = SpreadsheetApp; var ss = app.getActiveSpreadsheet().getSheetByName("NGワード"); var lr = ss.getLastRow(); for( var i=2 ; i <= lr ;i++){ var ckword = ss.getRange(i, 1).getValue(); if(word.indexOf(ckword) >= 0 ){ // return(true);//NGワードが見つかった return(i);//NGワードが見つかった行 } } return(false);//NGワードなし } function testJUDENGWORD(){ var ret = JUDGENGWORD("▲") console.log(ret) }
さらに、さらに
NGワードを一気に読み込む
- セルの値を一気に読み込んで処理する方法がわかります。
- 一気に読み込むので処理速度が速くなります。
スクリプト
function JudgeNGWord(word) { const NGWORDSHEET = "NGワード" const ss = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(NGWORDSHEET) const lr = ss.getLastRow() //NGワードの最下行 console.log(lr) let NgBuff = ss.getRange(2, 1, lr - 1).getValues() for (let i = 0; i < lr - 1; i++) { let ckword = NgBuff[i][0] console.log(ckword) if (word.indexOf(ckword) >= 0) { // return(true);//NGワードが見つかった return (ckword);//NGワードが見つかった行 } } return (false);//NGワードなし } function test_JudgeNGWord() { console.log(JudgeNGWord("〇〇")) }
動画はこちら
さらにさらに。。。
引数を一気に渡し一気に取得
- 関数の引数をまとめて渡す方法およびまとめて返す方法がわかります。
- 2重ループの行い方がわかります。
動画はこちら
スクリプト
function JudgeNGWordRange(words) { let retbuf = [] const NGWORDSHEET = "NGワード" const ss = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(NGWORDSHEET) const lr = ss.getLastRow() //NGワードの最下行 let NgBuff = ss.getRange(2, 1, lr - 1).getValues() for (let s = 0; s < words.length; s++) { //チェックする文字列のループ let word = words[s][0] //チェックする文字列 let bNG = false // true:NGワードが見つかった for (let i = 0; i < lr - 1; i++) { let ckword = NgBuff[i][0] if (word.indexOf(ckword) >= 0) { //NGワードが見つかった bNG = true retbuf.push(ckword) break } } if (!bNG)//NGワードが見つからなかったら retbuf.push(false) } return (retbuf) }
以上です。
最後までご覧いただきありがとうございます。
つぎはこちら
Googleシート 複数のNGワードを的確に抽出する方法
コメント
会社でスプレットシートを利用しているため、とても参考にさせていただいております。
「NGワードを表示させる」を参考にさせていただき、NGワードの抽出を行うことができ、とても参考になりました。
もし、可能であればぜひ動画を拝聴したいのですが、セルの中に文章を入れた際に、複数のNGワードが隣のセルに表示されるような仕組みを作ることは可能なのでしょうか。試しに作ってみたところ、一つの内容は表示されるのですが、NGワードが複数混じっていた場合はそのうちの一つしか表示することができませんでした。
差し支えなければご紹介いただけると幸いです。
差し支えなければ、実際に作られたシートやGAS(?)を
ご提供いただけないでしょうか?
そうしていただけると、話が早いです。
ご返信ありがとうございます。
お伝えの仕方が足りずすみません。
文章を取り扱う仕事をしており、文章のチェックの利用時に、シートもGasもご紹介されているNGワードを表示させるの内容が使えそうだと思い全く同じ内容で転用させていただきました。
GASなどプログラムを組めるほどの知識はないため、恥ずかしながらそのままの転用させていただいている状況です。
セルが文章かつ複数のNGワードがあった場合、ご紹介いただいているGASだとNGワードのうちの一つが表示されるかと思うのですが、文章の中に複数のNGワードが含まれていた場合にどのNGワードが含まれているのか一斉に出てくるとさらに良いなと思い、ご相談させていただきました。
現状の形式でも複数NGワードが含まれていた場合も、表示されたNGワードから修正していけばチェック機能として運用できるのですが、複数入っていた場合も列に文章を入れたセルのとなりの列に全てでできたらよいなと思った次第でした。
このたびはご丁寧にご返信いただき恐れ入ります。
TKさま
返信ありがとうございます。
で、問題となるシートのご提供は、難しいのでしょうか?
私が、TKさまの悩みをシートに起こすのは骨が折れます。
TKさまがシートを元に
具体的に、
「A2がこの場合、B3こうなってほしい」
と言った、明確な要望をしていただけると
回答できるかもしれません。
ご丁寧にご返信ありがとうございます。
このたびは申し訳ございません。
複数NGワードがふくまれていた場合に横の列にすべて出てくるような仕組みにしたいと考えておりました。
このようなシートとなっております。
https://docs.google.com/spreadsheets/d/19G18Uk_bCkKrAe3SsoAiTxMvQ-s8dViF3p5Im6Uu4Og/edit?usp=sharing
ちょっと意図しているものと異なるかもしれませんが
やってみました。
https://youtu.be/GjmE73gGaq4
NGであれば、また、連絡ください。
いつも学ばせていただいております。社内での実装を検討しているのですが、同一スプレッドシートのシートからNGワードを取得するではなく、別のスプレッドシートからNGワードの値を取得し、NGワードを判別したいスプレッドシートでそれを読み込んで表示させる事は可能なのでしょうか?
openByidでよみこんだり、ライブラリを試してみたのですが、上手くいかず悩んでおりました、、、
一気にやろうとせず、
一旦展開して、
「同一スプレッドシートのシートからNGワードを取得する」
状態にするのは、いかがですか?
コメントありがとうございます!
NGワードをオーナー以外分からない状態にしたいみたいで、同一スプレッドシートだと厳しいみたいなのですよね、、
なるほど、であればNGワードの取得を別シートから
読み込むようにすればいいと思います。
NGシートが決め打ちでいいのであれば
JudgeNGWordRange()内で、そのNGシードのIDを埋め込んでNgBuffに
読み込んでしまえばいけるのでは。
何度もありがとうございます!!
営業の成約した所をNGとしたいため、順次NGワードを更新していきたいと考えております。
この場合でも同様のやり方で実現可能なのでしょうか?
ぜひ、やってみてください!
返信遅くなりました汗
ありがとうございます!挑戦してみます!!