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

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

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

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

Q&A

解決済

1回答

13651閲覧

スプレッドシート、QUERY関数の正しい書き方についての質問

takoyaki87

総合スコア19

Google スプレッドシート

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

0グッド

0クリップ

投稿2020/04/19 10:35

スプレッドシートのquery関数を使い、指定した商品の販売個数を月ごとに表示したいです。

そこで、書き方を調べて次の数式を書いてみました。

=query('シート1'!C:L,"select C WHERE C contains '革' group by MONTH(G)",1)

ですが、下記のエラーメッセージが出てしまい関数が動かないです。

↓↓↓↓

「関数queryのパラメータ2のクエリ文字列を解析できません:CANNOT_GROUP_WITHOUT_AGG」

式の書き方に間違いがあるのかなと思うのですが、どの部分を直せば良いか、ぜひご教示いただけると幸いです。
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

幾つか修正点がありますが、まず該当のエラーが意味するところですが、
group by で まとめる場合、まとめた数値を得るための集計関数と組み合わせる必要があります。
(SUM、MAX、AVEなど) それが無いよ!っていうエラーです。
この場合は個数が欲しいので、COUNT ですね。select C → select count(C) 

あと、実現したいのは「指定した商品の販売個数を月ごとに表示」とのことなので、
select のところに 表示したい列(月毎)を追加してあげないといけません。
→ select month(G),count(C)

また、これは仕様なのですがQuery内のmonthは0スタート(1月が0、2月が1)となるので、
+1をしてあげることで 実際の月と同じになります。
→ select month(G)+1,count(C) (group by の後ろも同じく)

さらに言えば、データが年をまたいでないならよいですが、年をまたぐデータであれば、
2019年4月と2020年4月を区別する為に、年でもグループ化しておくと良いです。
→ select year(G),month(G)+1,count(C) ・・・ group by year(G),month(G)+1

これで希望の動きになりますでしょうか?

タイトル行が変な文字になっちゃうので、気になる用でしたら gropu by の記述の後に、
label year(G) '年',month(G)+1 '月'
を足してあげると良いです。(年、月のところは変更可)

■参考
https://tonari-it.com/spreadsheet-what-is-query/

投稿2020/04/20 00:51

sawa

総合スコア3002

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

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

takoyaki87

2020/04/20 04:48

コメントありがとうございます。 いただいたアドバイスをもとに修正してみましたところ、解決しました! 以下、完成した数式です。 =query('シート1'!C:L,"select year(G),month(G)+1,count(C) WHERE C contains '革' group by year(G),month(G)+1 label year(G) '年',month(G)+1 '月',count(C) '革・販売個数'",TRUE) 今回得た知識をもとに、さらにquery関数を学んでいきたいと思います。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問