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

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

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

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python

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

pandas

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

Q&A

解決済

2回答

6777閲覧

特定のカラム値で抽出したいがEmpty DataFrameになってしまう

8960

総合スコア108

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python

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

pandas

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

0グッド

0クリップ

投稿2021/12/02 05:11

編集2021/12/02 05:12

前提・実現したいこと

以下のようなデータフレームにおいて、カラム名"Season"の"2021"の行だけ抽出して新しくデータフレームを作成したいのですが、「Empty DataFrame」とエラーがでてしまい、空のデータフレームになってしまいます。

df=df.query('Season=="2021"')
↑原因はここだと思うのですが、何がおかしいのでしょうか?

ご教授の程、よろしくお願い致します。

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

Empty DataFrame Columns: [Season, Player, score1, score2, score3, score2/score3] Index: []

該当のソースコード

python

1import pandas as pd 2import numpy as np 3import random 4pd.options.display.float_format="{:.2f}".format 5#Create a random data frame 6N = 100 7players = [f"Player{i}"for i in range(1,31)] 8years = np.arange(2010,2022) 9years = np.random.choice(years,size=N) 10players=np.random.choice(players,size=N) 11df = pd.DataFrame({ 12 "Season": years, 13 14 "Player": players, 15 "score1": np.random.sample(N) * 10.0, 16 "score2": np.random.sample(N) * 10.0, 17 "score3": np.random.sample(N) * 10.0, 18}) 19 20df["score2/score3"]=df["score2"]/df["score3"] 21df=df.query('Season=="2021"') 22print(df) 23 24Empty DataFrame 25Columns: [Season, Player, score1, score2, score3, score2/score3] 26Index: []

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

windows11,python3.9.4,vscode

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

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

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

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

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

guest

回答2

0

df['Season'] の dtype は int になります。

python

1>>> df['Season'].dtype 2dtype('int64') 3 4>>> df.query('Season==2021') 5 Season Player score1 score2 score3 score2/score3 67 2021 Player1 3.26 3.94 9.14 0.43 78 2021 Player3 0.34 3.25 3.08 1.06 89 2021 Player18 4.45 3.26 4.79 0.68 912 2021 Player23 3.34 0.50 8.97 0.06 1013 2021 Player22 4.26 5.98 8.89 0.67 1121 2021 Player15 7.95 6.03 4.40 1.37 1252 2021 Player3 9.95 5.02 2.43 2.06 1379 2021 Player22 1.44 6.56 1.79 3.66 1484 2021 Player25 8.11 2.26 7.55 0.30 1590 2021 Player7 7.70 5.17 7.20 0.72

投稿2021/12/02 05:17

melian

総合スコア19714

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

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

8960

2021/12/02 05:20

あ!初歩的なミスでした。ありがとうございました。
guest

0

ベストアンサー

python

1df=df.query('Season==2021')

では?
(文字列ではなく数値)

投稿2021/12/02 05:16

bsdfan

総合スコア4560

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

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

8960

2021/12/02 05:20

初歩的なミスでした。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問