ご訪問ありがとうございます。
Googleシートマスターのひろしです。
前回
【GAS基礎講座 26.】行挿入し現在の行をコピペする方法(マクロの作成)
GASで行の追加ができます。
GASで行のコピペができます。
GASをショートカットキーで呼び出すことができます。
今回は、とっても価値の高い方法をお伝えします。
これを知ることであなたは、
- 最後に入力した値が、今までに入力していないかどうかをチェックすることができます。
- 配列内のチェックが簡単にできるようになります。
なので、サクッとマスターして
と答えてあげてください。
動画はこちら
※サムネは、基礎講座となっていますが中級以上ですね。
シートはこちら
※クリックするとシートが開きます。
スクリプト
チェックする値の取得
const CKROW = 5 //5列目 const ss = SpreadsheetApp.getActiveSpreadsheet() const sh = ss.getActiveSheet() const val = sh.getActiveCell().getValue() const lrow = sh.getActiveCell().getRow() const ckvaluse = sh.getRange(2, CKROW, lrow - 2).getValues()
ループでやった場合
for(let i=0;i<lrow-2;i++){ console.log(ckvaluse[i][0]) if(ckvaluse[i][0] === val){ console.log("すでに使用済み") } }
forEachでやった場合
ckvaluse.forEach(item => { console.log(item) if (item[0] === val) { console.log("すでに使用済み") } })
someでやった場合
let ret = ckvaluse.some(item => item[0] === val) if (ret) { console.log("すでに使用済み") }
let ret = ckvaluse.some(item => item[0] === val)
だけでいけちゃいます。
someのイメージ
ret = ckvaluse.some(function (item, i, ckvaluse) { if (item[0] === val) { console.log("すでに使用済み") return (true) } })
最後までご覧いただきありがとうございます。
つぎはこちら
【GAS】日付形式の設定とセル内で改行させる方法(エスケープ文字)