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

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

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

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

Q&A

解決済

2回答

806閲覧

Pythonでの表の作成について

1mzmk

総合スコア42

Python

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

0グッド

0クリップ

投稿2019/03/28 10:29

私はあるjsonファイルを使用しています。
私のjsonファイルはワインについてのレビューについてのデータで、多くの種類のワインのレビューについてリストとして記載されています。行には”country”,"variety", "price", "point", "description"などの項目があります。
また、ワインの種類に関しては”variety”の列に記載されております。
イメージ説明

'https://github.com/tulip-lab/sit742/raw/master/Assessment/2019/data/wine.json'
こちらが私が使用してるjsonファイルです。

groupby()を使用して私のjsonファイルにおいて、
私はまず、
”country”ごとに
それぞれの国で最もレビューを受けとったワインの種類、
それぞれの国での”point”の平均値
それぞれの国での”price”の平均値
に関する表を作りたいと考えており、

”country”ごとの
それぞれの国での”point”の平均値
それぞれの国での”price”の平均値
に関する表の作り方に関しては
df.groupby(['country']).agg({'price':['mean'], 'points':['mean']})によって作成できることを
他の方に教えて頂き、
作成できたのですが、
その表に更に
”country”ごとに
最も一番レビューを受けとったワインの種類の列を追加した表を作成したいと考えているのですが
その作成するためのコードがわかりません。

なので、分かる方いらっしゃいましたら、よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

http://teratail.com/questions/181382
にも書いておりますが、まず 国、銘柄毎に point,price 列の最大・平均.最小の値を求める方法は Groupby.agg() を使って

Python

1df.groupby(['country','variety']).agg({'price':['min','mean','max'], 'points':['min','mean','max']})

となり、これと同時に descriptionの数をカウントするためには、

Python

1tmp_df = df.groupby(['country','variety']).agg({'price':['min','mean','max'], 'points':['min','mean','max'],'description':'count'})

とでもすると良いわけです。

あとは上記の DataFrame から 国ごとに description の数が最大な行を抜き出すとよいわけですが、
これは上記のデータフレーム(tmp_df) に対して再度、国ごとに groupby() を使って行うことができます。

具体的なコードをわかりやすく for文を使って書くと

Python

1# 国毎に選択された銘柄の行を格納するリスト 2dfs = [] 3# groupby() によって国毎のデータでループ 4for country, data in tmp_df.groupby('country'): 5 # description数が最大な行のIndexを求める 6 idx = data[('description','count')].idxmax() 7 # 上の行をリストに格納 8 dfs.append(tmp_df.loc[[idx]]) 9# リスト内のデータを結合してデータフレームを再構築 10result = pd.concat(dfs)

となるかと思います。

投稿2019/03/28 10:50

編集2019/03/28 11:50
magichan

総合スコア15898

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

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

0

レビューにあたる列がどれか分かりませんでしたので、reviewとさせていただきましたが、以下のような集計処理でよろしかったでしょうか。

df["rank"]=df.groupby("country")["review"].rank(ascending=True,method="first")

投稿2019/03/28 10:50

bamboo-nova

総合スコア1408

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問