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

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

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

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

Q&A

解決済

2回答

8879閲覧

行数が違うシートのデータをコピーするとき

manah1212

総合スコア12

Google Apps Script

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

0グッド

0クリップ

投稿2017/05/19 14:40

編集2017/05/19 15:12

GoogleAppsScriptで、行数の違うシート(スプレッドシート)のデータをほかのシートにコピーする際に
行数が違うことによるエラーが発生します。

ただ、シートの場合は、手作業で行数をそろえたらよいのですが、違うスプレッドシートの際は、
手作業でそろえるには、少し厳しいものがあります。

このエラーを解消する方法はあるのでしょうか。
ご教授いただければと思います。

追記:
エラーメッセージは以下のようなものです。
320 は無効な高さです。1320 にする必要があります。

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

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

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

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

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

guest

回答2

0

自己解決

解決しました!
列の最終行を求めるScriptを作成し、そのデータ範囲で取得セットするようにしました。
もっと良い方法がありそうですが、ひとまず、このようにしました。

=====
var sheet_copyFrom = copyFrom.getSheetByName('シート1');
var var mValue =sheet_copyFrom.getRange('C:C').getValues();
var lastRow = mValue.filter(String).length;
var var sheet_copyTo =copyTo.getSheetByName('シート2');
var rangeTo = "A1:A"+lastRow;
var rangeFrom = "C1:C"+lastRow;

var mValues = sheet_copyFrom.getRange(rangeFrom).getValues();
sheet_copyTo.getRange(rangeTo).setValues(mValues);

投稿2017/05/20 03:18

manah1212

総合スコア12

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

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

0

Rangeが違うってエラーですよね?同じrangeである必要があるので、対象範囲をあわせてください。

少し厳しいものがあります。

というか、エラーメッセージを載せずに回答を募るのも少し厳しいものがあると思います。

投稿2017/05/19 14:42

編集2017/05/19 14:43
harashow1701

総合スコア854

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

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

manah1212

2017/05/19 15:17

ご回答、ありがとうございます。 エラーメッセージがないご指摘、大変申し訳ございません。 質問内容にも追記しましたが、以下のようなものです。  320 は無効な高さです。1320 にする必要があります。 補足:   320はコピー元のシートの行数です。  1320はコピー先のシートの行数です。 確かに、A列取得して、別シートのA列に張り付ける場合 データあるなしにかかわらず、A列全体を取得するので、行数が違うと Rangeエラーになるということですよね。 シートの行数まで合わせないといけないということになりますね。
harashow1701

2017/05/19 15:22

はい、範囲を合わせる必要があります。公開されてる情報が限られているので、これ以上は何も答えられません。
manah1212

2017/05/19 15:34

ご回答、ありがとうございます。 ただ、公開されている情報以上の情報はないです。範囲を合わせるように、手作業で行数の調整を行います。
harashow1701

2017/05/19 15:38

手作業でやる必要はないはずですが、公開されてる情報がこれ以上ない場合は手作業で頑張ってください。
manah1212

2017/05/19 15:45

たとえば、シート1が320行のシートとします。 そこに、100行のデータが入っています。 そのデータをシート2(これは、1320行のシートです)にコピーしたいときは、 どのようにすれば、Rangeのエラーがなくなるのでしょうか。 あ、コードを記載しておりませんでした。 大変、失礼いたしました。 以下のように記述しております。 ==========  var sheet_copyFrom = copyFrom.getSheetByName('シート1'); var mValue =sheet_copyFrom.getRange('C:C').getValues(); var sheet_copyTo =copyTo.getSheetByName('シート2'); sheet_copyTo.getRange('A:A').setValues(mValue); ======== ご教授いただければと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問