🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Google スプレッドシート

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

Q&A

解決済

2回答

1662閲覧

Google スプレッドシート で、特定のセルの文字列を利用して、Queryで複数範囲を指定したい。

KeikiBanana

総合スコア11

Google スプレッドシート

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

0グッド

0クリップ

投稿2019/10/02 13:45

Google スプレッドシートで Query をしたい。
任意のセルの文字列を利用して複数範囲指定したい。

Google スプレッドシート で Query を使いたいです。

F1のセルで、
=Query{A1:B4;C5:D10}
上の式の結果を得たいです。

しかし、上の式を直接入力せずに、
E1 に {A1:B4;C5:D10}
と入力して、それを利用して実行したいです。

=Query(INDIRECT(E1))
としてみましたが、

関数 INDIRECT のパラメータ 1 の値が「{A1:B4;C5:D10}」です。
これは無効なセル/範囲の参照です。

とエラーがでました。
なにかいい方法はありますでしょうか。

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

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

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

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

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

guest

回答2

0

ベストアンサー

INDIRECT()の関数の中に ** ; ** が入っちゃうからうまくいかないのかと。
あと** { **と } もF1セルがわで書くとして、2通りの方法が考えられます。

その1
E1 に A1:B4
E2 に C5:D10
と書いて
F1 に
=Query({INDIRECT(E1);INDIRECT(E2)})

その2
E1 に A1:B4;C5:D10
と書いて
F1 に
=Query({INDIRECT(LEFT(E1,FIND(";",E1)-1));INDIRECT(RIGHT(E1,(LEN(E1))-FIND(";",E1)))})

↑ 一回 ; の前後でバラして 再度くっつける感じ

もっとスマートな書き方があるかもしれませんが、とりあえず上記で可能です。

投稿2019/10/03 07:08

sawa

総合スコア3002

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

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

KeikiBanana

2019/10/03 12:36

その2で解決しました。 ありがとうございました。
guest

0

何かいい方法というのがわかりませんが、タイトルに合いそうな記事を見つけました。

【スプレッドシート】QUERY関数で複数範囲・複数シートを結合する

投稿2019/10/02 14:46

toolscloudy

総合スコア20

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

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

KeikiBanana

2019/10/02 14:53

回答ありがとうございます。 ご紹介の記事では解決できませんでした。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問