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

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

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

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

Python

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

pandas

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

Q&A

解決済

2回答

440閲覧

ファイル名にクエリに入れた値を自動で入力したい

8960

総合スコア108

NumPy

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

Python

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

pandas

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

0グッド

0クリップ

投稿2022/02/10 07:09

編集2022/02/10 08:47

前提・実現したいこと

以下のコードにおいて、下から4番目でPlayerを”Player1”に限定しています。
df_player = dfx.query('Player=="Player1"')

csvへのエクスポートのところで、
df_player.to_csv("C:/Users/DELL/Downloads/Player1.csv")
とファイル名を手動で指定していますが、このファイル名指定を
クエリに入れた値が自動で入力されるようにするにはどうすればよいでしょうか?

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

ソースコード

Python

1import pandas as pd 2import numpy as np 3from scipy.stats import variation 4pd.options.display.float_format="{:.1f}".format 5start,end = "2021/4/1","2021/4/30" 6dates = pd.date_range(start=start,end=end,freq="D") 7players = [f"Player{i}"for i in range(1,6)] 8 9N = 200 10dates = np.random.choice(dates,size=N) 11dates.sort() 12players=np.random.choice(players,size=N) 13 14df = pd.DataFrame({ 15 "Date": dates, 16 "Player": players, 17 "Speed": np.random.sample(N) * 100.0, 18 "Angle": np.random.sample(N) * 40.0 - 20.0, 19 "Efficiency": np.random.sample(N) * 100.0, 20}) 21 22def percentile(n): 23 def percentile_(x): 24 return np.percentile(x, n) 25 percentile_.__name__ = '%sth' % n 26 return percentile_ 27 28dfx = df.groupby(["Player"]).agg({ 29 "Player":"count", 30 "Speed":[np.mean,percentile(90),np.max,lambda x: np.std(x),np.min,variation], 31 "Angle":[np.mean,np.std], 32 "Efficiency":[np.mean], 33 }) 34#select Player 35df_player = dfx.query('Player=="Player1"') 36print(df_player) 37#export 38df_player.to_csv("C:/Users/DELL/Downloads/Player1.csv")

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

VSCode、python3.9

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

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

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

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

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

guest

回答2

0

別解として。

python

1#export 2#df_player.to_csv("C:/Users/DELL/Downloads/Player1.csv") 3df_player.to_csv(f"C:/Users/DELL/Downloads/{df_player.index[0]}.csv")

投稿2022/02/10 07:54

melian

総合スコア19714

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

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

8960

2022/02/10 08:46

ありがとうございます!
guest

0

ベストアンサー

やりたいことは、たぶん以下でできるでしょう。

python

1#select Player 2player = 'Player1' 3df_player = dfx.query('Player=="Player1"') 4print(df_player) 5#export 6df_player.to_csv(f"C:/Users/DELL/Downloads/{player}.csv")

投稿2022/02/10 07:40

ppaul

総合スコア24666

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

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

8960

2022/02/10 07:52 編集

ありがとうございました。おかげさまでf{}の使い方を理解することが出来ました。 手動で入力する枠を1つにしたかったので #select Player player = "Player2" df_player = dfx.query(f'Player=="{player}"') print(df_player) #export df_player.to_csv(f"C:/Users/DELL/Downloads/{player}.csv") とクエリ行も少しだけ変更しました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問