亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Seaborn.countplot:按計數排序類別,也按類別?

Seaborn.countplot:按計數排序類別,也按類別?

回首憶惘然 2021-12-21 17:44:18
所以我了解如何對條形圖進行排序(即這里)。但我找不到的是如何按子類別之一對條形圖進行排序。例如,給定以下數據框,我可以獲得條形圖。但是我想做的是將它從最大到最小排序,由Typeof Classic)。import pandas as pdtest_df = pd.DataFrame([['Jake',    38, 'MW',   'Classic'],['John',    38,'NW',    'Classic'],['Sam', 34, 'SE',   'Classic'],['Sam', 22, 'E' ,'Classic'],['Joe', 43, 'ESE2', 'Classic'],['Joe', 34, 'MTN2', 'Classic'],['Joe', 38, 'MTN2', 'Classic'],['Scott',   38, 'ESE2', 'Classic'],['Chris',   34, 'SSE1', 'Classic'],['Joe', 43, 'S1',   'New'],['Paul',    34, 'NE2',  'New'],['Joe', 38, 'MC1',  'New'],['Joe', 34, 'NE2',  'New'],['Nick',    38, 'MC1',  'New'],['Al',  38, 'SSE1', 'New'],['Al',  34, 'ME',   'New'],['Al',  34, 'MC1',  'New'],['Joe', 43, 'S1',   'New']], columns = ['Name','Code_A','Code_B','Type'])import seaborn as snssns.set(style="darkgrid")palette ={"Classic":"#FF9999","New":"#99CC99"}g = sns.countplot(y="Name",                  palette=palette,                  hue="Type",                  data=test_df)所以而不是:'Joe' 將在上面,然后是 'Sam',等等。
查看完整描述

2 回答

?
互換的青春

TA貢獻1797條經驗 獲得超6個贊

添加order參數。使用pandas.crosstab和sort_values來獲得:


import pandas as pd


test_df = pd.DataFrame([

['Jake',    38, 'MW',   'Classic'],

['John',    38,'NW',    'Classic'],

['Sam', 34, 'SE',   'Classic'],

['Sam', 22, 'E' ,'Classic'],

['Joe', 43, 'ESE2', 'Classic'],

['Joe', 34, 'MTN2', 'Classic'],

['Joe', 38, 'MTN2', 'Classic'],

['Scott',   38, 'ESE2', 'Classic'],

['Chris',   34, 'SSE1', 'Classic'],

['Joe', 43, 'S1',   'New'],

['Paul',    34, 'NE2',  'New'],

['Joe', 38, 'MC1',  'New'],

['Joe', 34, 'NE2',  'New'],

['Nick',    38, 'MC1',  'New'],

['Al',  38, 'SSE1', 'New'],

['Doug',    34, 'ME',   'New'],

['Fred',    34, 'MC1',  'New'],

['Joe', 43, 'S1',   'New']], columns = ['Name','Code_A','Code_B','Type'])



import seaborn as sns

sns.set(style="darkgrid")

palette ={"Classic":"#FF9999","New":"#99CC99"}


order = pd.crosstab(test_df.Name, test_df.Type).sort_values('Classic', ascending=False).index

g = sns.countplot(y="Name",

                  palette=palette,

                  hue="Type",

                  data=test_df,

                  order=order

                 )

http://img1.sycdn.imooc.com//61c1a218000116ba04320288.jpg

查看完整回答
反對 回復 2021-12-21
?
鳳凰求蠱

TA貢獻1825條經驗 獲得超4個贊

import pandas as pd


test_df = pd.DataFrame([

['Jake',    38, 'MW',   'Classic'],

['John',    38,'NW',    'Classic'],

['Sam', 34, 'SE',   'Classic'],

['Sam', 22, 'E' ,'Classic'],

['Joe', 43, 'ESE2', 'Classic'],

['Joe', 34, 'MTN2', 'Classic'],

['Joe', 38, 'MTN2', 'Classic'],

['Scott',   38, 'ESE2', 'Classic'],

['Chris',   34, 'SSE1', 'Classic'],

['Joe', 43, 'S1',   'New'],

['Paul',    34, 'NE2',  'New'],

['Joe', 38, 'MC1',  'New'],

['Joe', 34, 'NE2',  'New'],

['Nick',    38, 'MC1',  'New'],

['Al',  38, 'SSE1', 'New'],

['Al',  34, 'ME',   'New'],

['Al',  34, 'MC1',  'New'],

['Joe', 43, 'S1',   'New']], columns = ['Name','Code_A','Code_B','Type'])



import seaborn as sns

sns.set(style="darkgrid")

palette ={"Classic":"#FF9999","New":"#99CC99"}


sb.countplot(y = 'Name', hue='Type', data=test_df, 

order=test_df['Name'].value_counts().index)

http://img1.sycdn.imooc.com//61c1a22600019d4f04030265.jpg

查看完整回答
反對 回復 2021-12-21
  • 2 回答
  • 0 關注
  • 229 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號