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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

1回答

972閲覧

Pandasで移動平均を求めて、辞書をソートするプログラムの作成

takumi-33

総合スコア19

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2021/07/11 19:26

前提・実現したいこと

3つのCVSファイルを読み込んで、7データごとに移動平均を求めて、その値が1.0以下である回数を数えます。
その数が多い順に辞書をソートして、キーリストを表示するプログラムを作成したいです。

発生している問題・エラーメッセージ

プログラマを作ることはできたのですが、ソートを実行する際にエラーが表示されています。

このエラーを解消することができなくて困っています。

The truth value of a Series is ambiguous. Use a.empty, a.bool(), a.item(), a.any() or a.all().

該当のソースコード

Python

1import pandas as pd 2 3CITY_LABEL=['takamatsu','naha','wakkanai'] 4CITY_NAME=['高松','那覇','稚内'] 5 6# CSVファイルを読み込み,データフレームに変換する 7def get_dataframe_city(_label): 8 datadir='./data/' 9 return pd.read_csv(datadir+'weather_'+_label+'.csv') 10 11 12def sort(dictionary): #大きい順に値をソートして、キーのみを返す関数 13 sorted_items = sorted(dictionary.items(), key=lambda x: x[1], reverse=True) 14 sorted_keys = [x[0] for x in sorted_items] 15 return sorted_keys 16 17 18window = 7 #移動平均区間 19 20data_takamatsu = (df[CITY_NAME[0]].loc[:,["降水量の合計"]].rolling(window).mean() <= 1.0) 21data_takamatsu.sum() #高松の降水量の合計の移動平均が1mm以下の回数を数える 22 23data_takamatsu = (df[CITY_NAME[1]].loc[:,["降水量の合計"]].rolling(window).mean() <= 1.0) 24data_naha.sum() #那覇の降水量の合計の移動平均が1mm以下の回数を数える 25 26data_takamatsu = (df[CITY_NAME[2]].loc[:,["降水量の合計"]].rolling(window).mean() <= 1.0) 27data_wakkanai.sum() #稚内の降水量の合計の移動平均が1mm以下の回数を数える 28 29rain_amount = {CITY_NAME[0]:data_takamatsu.sum(),CITY_NAME[1]:data_naha.sum(),CITY_NAME[2]:data_wakkanai.sum()} #各場所の雨が降らなかった日の数の辞書 30 31sort(rain_amount)

試したこと

関数は、辞書型の値の型が'numpy.float64'のときは正常に動作したのですが、

data_takamatsu.sum() , data_naha.sum() , data_wakkanai.sum()
のデータ型が'pandas.core.series.Series'となっているから正常に動作していないのだとは分かりました。

型変換で、.astype('float64')を行っても、エラーは表示されました。

また、エラーコードを検索して、内容を調べたのですが、
・条件式の書き方が誤っている → 条件式は1つしかないので、おそらく関係ない
・真理値の値が曖昧である → 対策方法が分からない
ということが分かりました。

補足情報(FW/ツールのバージョンなど)

jupiter notebook , pandasを使用しています。

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

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

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

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

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

guest

回答1

0

python

1data_takamatsu = (df[CITY_NAME[0]].loc[:, "降水量の合計"].rolling(window).mean() <= 1.0)

にすればできると思います。(他の都市も同様です)

python

1df[CITY_NAME[0]].loc[:, ["降水量の合計"]]

は列が1つだけのDataFrameで、

python

1df[CITY_NAME[0]].loc[:, "降水量の合計"]

は、Seriesです。
(それらをrolling().mean()してもDataFrameはDataFrame、SeriesはSeriesです)

sum()をとったとき、Sereis.sum()はスカラー値ですが、DataFrame.sum()はSeriesになります。

投稿2021/07/12 02:43

bsdfan

総合スコア4794

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問