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

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

新規登録して質問してみよう
ただいま回答率
85.47%
Google ドキュメント

Google ドキュメントは、Google社が提供している文書作成ツール。Googleアカウントがあれば無料で利用できます。ブラウザ上で文書作成を行い、複数人での同時編集がで可能。スマホやタブレットでも利用できる他、オフラインでの編集もできます。

Q&A

解決済

1回答

310閲覧

スプレッドシートからGASで転記→リンク付のデータが外れてしまう

nocci

総合スコア7

Google ドキュメント

Google ドキュメントは、Google社が提供している文書作成ツール。Googleアカウントがあれば無料で利用できます。ブラウザ上で文書作成を行い、複数人での同時編集がで可能。スマホやタブレットでも利用できる他、オフラインでの編集もできます。

0グッド

2クリップ

投稿2024/01/26 03:51

編集2024/01/30 04:21

シート1のI列にリンク付きのデータが保存されていて、
その列のデータをシート2のI列に転記し、
リンク付のデータはリンク付きのまま転記したい

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

調べても出てこず...

補足

特になし

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

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

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

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

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

guest

回答1

0

ベストアンサー

js

1const value = sheet.getRange(...).getValue(); 2const values = sheet.getRange(...).getValues();

のようにデータを取得してしまうとセルに表示されている値のみが取得されますので、
リンクをを含んだままの状態のセルの値(リッチテキスト値)を取得するには、

js

1const richValue = sheet.getRange(...).getRichTextValue(); 2const richValues = sheet.getRange(...).getRichTextValues();

のように記述します。
また、取得したリッチテキスト値をシートに記入するときは、

js

1sheet.getRange(...).setRichTextValue(richValue); 2sheet.getRange(...).setRichTextValues(richValues);

のように記述します。

例えば、
シート1のI列にリンク付きのデータが保存されていて、
その列のデータをリンク付のデータはリンク付きのままシート2のI列に転記する場合は、
次のスクリプトのようになります。

js

1function myFunction() { 2 // 初期設定 3 const ss = SpreadsheetApp.getActiveSpreadsheet() 4 const sheet1 = ss.getSheetByName('シート1'); 5 const sheet2 = ss.getSheetByName('シート2'); 6 const lastRow1 = sheet1.getLastRow(); // シート1の最終行 7 const startRow1 = 2;// シート1の開始行 8 const startRow2 = 2;// シート2の開始行 9 const urlCol1 = 9; // シート1のリンク付きの列(I列) 10 const urlCol2 = 9; // シート2の記入先の列(例えばI列) 11 12 // 特定の列のリンク付の値を他のシートの指定の列に記入 13 const richValues = sheet1 14 .getRange(startRow1, urlCol1, lastRow1 - startRow1 + 1, 1) 15 .getRichTextValues(); 16 sheet2.getRange(startRow2, urlCol2, richValues.length, richValues[0].length) 17 .setRichTextValues(richValues); 18}

お示しのコードでも、
I 列のデータの取得と記入のところで
取得(valueAdd4)のところで、.getValues().getRichTextValues() に変更し、
記入(add4)のところで、.setValues().setRichTextValues() に変更することで動作するようになると思います。

投稿2024/01/26 04:32

編集2024/01/29 10:45
YellowGreen

総合スコア731

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

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

nocci

2024/01/26 06:04 編集

言葉足らずですみません。 現状のコードです。 シート1のI列に =IF(COUNTIFS(AK7,"xxxxx",AN7,"xxxxx"),HYPERLINK("URL","参照"),"") このような関数が入っています。 リンク付きの「参照」という値を挿入したいということでOKです。
YellowGreen

2024/01/26 05:19

> 現状のコードです。 > シート1のI列に > =IF(COUNTIFS(AK7,"xxxxx",AN7,"xxxxx"),HYPERLINK("URL","参照"),"") > このような関数が入っています。 > リンク付きの「参照」という値を挿入したいということでOKです。 ごめんなさい。 おっしゃる意味がわかりませんので、どうしたいのかが不明です。 お示ししたコードでリンク付きの値を挿入できますので、 質問者様が ご自身でコードを修正してみて、 不具合がありましたら再度ご質問してみてください。
YellowGreen

2024/01/29 07:25

質問のタイトルや内容は、編集できます、 ご自身のコードの修正方法をお知りになりたいのであれば、 質問のタイトルと内容を編集して、 ご自身のコードをコメントではなく質問の方に記載して 何をどうしたいか(どのシートのどの列の値をどのシートのどの列に記入したいなど) 試したけれどできなかったことなどを できるだけ具体的に記入して コードの修正方法を尋ねる質問に変更されてはどうでしょうか。
nocci

2024/01/29 08:28

いつもありがとうございます。。。 少し内容を変えてみました。どうでしょう。。。
YellowGreen

2024/01/29 08:35

const valueAdd4 = sheet1.getRange(rowBegin, colAdd7, lastRow1 - rowBegin + 1, 1).getValues(); ↓ const valueAdd4 = sheet1.getRange(rowBegin, colAdd7, lastRow1 - rowBegin + 1, 1).getRichTextValues(); と sheet2.getRange(lastRow2 + 1, colAdd8, add4.length, add4[0].length).setValues(add4); ↓ sheet2.getRange(lastRow2 + 1, colAdd8, add4.length, add4[0].length).setRichTextValues(add4); は試されましたか?
nocci

2024/01/30 00:10

ありがとうございます。 上記のコードで試したのですがうまくいきません。。。 シート1のI列にリンク付きのデータが保存 リンク付きのままシート2のR列に転記(列、書き間違えてました。) (上に画像貼りました。)
YellowGreen

2024/01/30 03:59 編集

説明がないままの画像を貼られてもよくわかりません。 私のところでは、上のコードでリンク付きデータが最終行に挿入されています。 うまくいかないとは、どうなっているのかを具体的に書いてください。 I 列のデータが R 列の最終行に転記されていて、リンクがない状態になっているのでしょうか。 それとも、何も転記されていないのでしょうか。もしそうなら、R列の最後のデータでCTRLキーと▼キーを押してみてください。 エラーになっているのであれば、エラーの内容のコピペしてみてください。
nocci

2024/01/30 04:14

失礼しました。。。 I 列のデータがシート2のR列の最終行に転記されるのですが、リンクが外れてしまい、文字だけが転記されている状態です。 エラーにはなっていないです。
nocci

2024/01/30 04:21 編集

あ、ごめんなさい。。 今見たら、文字の上にカーソル当てたらリンク貼られていました。 ブルーになって下線が引かれないのですね
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問