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

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

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

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

JavaScript

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

Q&A

解決済

1回答

789閲覧

GAS 指定文字があった場合のクリア

ArataTsugawa

総合スコア1

Google Apps Script

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

JavaScript

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

0グッド

0クリップ

投稿2021/05/20 06:52

編集2021/05/21 00:12

①指定の列が"完了"となれば"完了"となっている行全体を別シートに貼り付け
②元シートの指定の列が"完了"となっている行のセル(例2列目、5列目、7列目)をクリアするにはどうすればよいでしょうか。
"完了"となる列は16列目になります。(A行からでP行にあたる)
※よく似た元ソースは見つけたのですが、列全体を削除してしまいます。
よろしくお願いします。

function triggeredCutPaste() { const spreadsheet = SpreadsheetApp.getActiveSpreadsheet(); const src = spreadsheet.getSheetByName("○○"); const dst = spreadsheet.getSheetByName("○○"); copyPaste(src, dst); deleteRows(src); } function copyPaste(src, dst) { const finished = src.getDataRange().getValues() .filter(function(element, index, array) { return element[15] === "完了"; }); if(finished.length > 0) { dst.getRange(dst.getLastRow() + 1, 1, finished.length, finished[0].length).setValues(finished); } } function deleteRows(sheet) { sheet.getDataRange().getValues() .map(function(element, index, array) { return [index + 1, element[15]] }).filter(function(element, index, array) { return element[1] === "完了"; }).map(function(element, index, array){ return element[0]; }).reverse().forEach(function(element, index, array){ sheet.deleteRow(element); }); }

追記
|A|B|C|D|~|O|P|
|:--|:--:|--:|
|あ|い|う|え|~|た|完了|

例えですがP列に完了が入ると別シートに行全体がコピペされ
元シートの「い」「え」だけクリアされるイメージです。

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

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

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

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

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

K_3578

2021/05/20 07:00

JavaじゃなくてJavaScriptでは?>タグ GASもタグ有るので追加してください。 ソースコードはMarkDownのcode機能でブロック化してご提示ください。 ```JavaScript コード ``` 上記のようにバッククォートでソースコードを囲むとコードが見やすくなります。
ArataTsugawa

2021/05/20 07:07

ご指摘ありがとうございます! 修正致しました。
papinianus

2021/05/20 17:07

AからPは列です。行は1,2,3の方向です。状況がわからないので、シートのサンプルを示してくださいませんか。
guest

回答1

0

ベストアンサー

gas

1function deleteRows(sheet) { 2 sheet.getDataRange().getValues() 3 .map(function(element, index, array) { 4 return [index + 1, element[15]] 5 }).filter(function(element, index, array) { 6 return element[1] === "完了"; 7 }).map(function(element, index, array){ 8 return element[0]; 9 }).reverse().forEach(function(element, index, array){ 10 sheet.deleteRow(element); 11 }); 12}

これ、ArataTsugawaさん理解されてますか?
コピペだと思うんですが、慣れないうちめちゃくちゃ分かりにくいの分解してやられた方がいいですよ。

こんな感じですね。

一度全ての値を取得し、必要な処理を行い、
コピー元、コピー先のシートを両方ともクリアし貼り付ける。

 

gas

1 2 const spreadsheet = SpreadsheetApp.getActiveSpreadsheet(); 3 const copySheet = spreadsheet.getSheetByName("○○"); //コピー元 4 var copyValues = copySheet.getDataRange().getValues() //全データ 5 var results = [] //結果 //元データ貼り付け用 6 var results2 = [] //完了該当結果 貼り付け用 7 8  9 10//全データを回す 11 copyValues.forEach(e=>{ 12 if(e[15] == "完了"){ 13 results2.push(e) 14    var item = Object.assign({}, e); // 15 16 item[1] = "" //2列目を消す 17 item[4] = "" //5列目を消す 18 item[6] = "" //7列目を消す 19 20 results.item(item) 21 }else{ 22 results.item(e) 23 } 24 }) 25 26 //コピー元のシートを消去して、修正を加えたデータを貼り付ける。 27 copySheet.clear(); 28 copySheet.getRange(1,1,results.length,results[0].length).setValues(results) 29 30 31 32 const copyToSheet = spreadsheet.getSheetByName("○○"); //コピー先 33 //コピー先のシートを消去して、該当するデータを貼り付ける。 34 copyToSheet.clear(); 35copyToSheet.getRange(1,1,results2.length,results2[0].length).setValues(results2)  36 37 38 39 40

投稿2021/05/21 02:35

Tatsunosuke

総合スコア599

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

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

ArataTsugawa

2021/05/21 06:58

Tatsunosukeさん ありがとうございます。 最近スクリプトを理解しようと勉強している超初心者になります。 一度試してみます。そしてなぜこのような処理が行われるのか勉強します。
Tatsunosuke

2021/05/21 09:46

はい!頑張ってください! 基本的には、GASは ①シートからデータを読み込む ②加工する ③シートへは張り付ける 大体これだけです! まずは、配列・連想配列、この理解が進めばプログラミングも進みやすくなると思います!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問