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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

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

Q&A

解決済

1回答

1485閲覧

Googleスプレッドシート、GASでリッチテキストを置換する場合のGAS

mbcztpw

総合スコア30

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google Apps Script

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

0グッド

1クリップ

投稿2023/04/13 03:19

編集2023/04/17 06:58

以下のように、セル内にURLリンクを含むセル内の文字列「データA」をGASで「Data1」に置換します。
<置換前>
イメージ説明

URLリンクを含んだ文字列の場合、getRichTextValuesを使うと情報を取得できると分かったのですが、
以下プログラムを実行するとURLリンクが消えてしまいます。
どのようにすればよいでしょうか。
よろしくお願いします。

GAS

1function replace1() { 2 let ss = SpreadsheetApp.getActiveSpreadsheet(); 3 let sheet = ss.getSheetByName("シート1") 4 let range = sheet.getRange(2,1,3,2).getRichTextValues(); 5 for(let cnt=0; cnt<range.length; cnt++){ 6 range[cnt][0] = range[cnt][0].getText().replace(/データA/g,"Data1"); 7 range[cnt][1] = range[cnt][1].getText().replace(/データA/g,"Data1"); 8 } 9 sheet.getRange(2,1,3,2).setValues(range); 10}

<置換後>
イメージ説明
リンクが消える

下記変更しましたが、今度は処理対象のすべてのセルが「RichTextValue」になりました。

GAS

1function replace1() { 2 let ss = SpreadsheetApp.getActiveSpreadsheet(); 3 let sheet = ss.getSheetByName("シート1") 4 let range = sheet.getRange(2,1,3,2).getRichTextValues(); 5 for(let cnt=0; cnt<range.length; cnt++){ 6 // range[cnt][0] = range[cnt][0].getText().replace(/データA/g,"Data1"); 7 // range[cnt][1] = range[cnt][1].getText().replace(/データA/g,"Data1"); 8 9 var text = range[cnt][0].getText().replace(/データA/g,"Data1"); 10 var builder = SpreadsheetApp.newRichTextValue(); 11 builder.setText(text); 12 range[cnt][0].getRuns().forEach(run => { 13 const startOffset = run.getStartIndex(); 14 const endOffset = run.getEndIndex() ; 15 const style = run.getTextStyle(); 16 builder.setTextStyle(startOffset, endOffset, style); 17 }); 18 var newValue = builder.build(); 19 range[cnt][0] = newValue; 20 21 text = range[cnt][1].getText().replace(/データA/g,"Data1"); 22 builder = SpreadsheetApp.newRichTextValue(); 23 builder.setText(text); 24 range[cnt][1].getRuns().forEach(run => { 25 const startOffset = run.getStartIndex(); 26 const endOffset = run.getEndIndex() ; 27 const style = run.getTextStyle(); 28 builder.setTextStyle(startOffset, endOffset, style); 29 }); 30 newValue = builder.build(); 31 range[cnt][1] = newValue; 32 33 } 34 sheet.getRange(2,1,3,2).setValues(range); 35}

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

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

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

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

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

mbcztpw

2023/04/21 05:30

ご提案ありがとうございました。
guest

回答1

0

自己解決

sawa様
TextFinder のご提案ありがとうございます。
以下のようにできました。

GAS

1function replace1() { 2 let ss = SpreadsheetApp.getActiveSpreadsheet(); 3 let sheet = ss.getSheetByName("シート1") 4 let finder = sheet.createTextFinder("データA"); 5 let cnt = finder.replaceAllWith("Data1"); 6 SpreadsheetApp.getUi().alert(cnt + "件置換しました。"); 7}

投稿2023/04/21 05:30

mbcztpw

総合スコア30

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問