第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

Seaborn.countplot:按計數(shù)排序類別,也按類別?

Seaborn.countplot:按計數(shù)排序類別,也按類別?

回首憶惘然 2021-12-21 17:44:18
所以我了解如何對條形圖進(jìn)行排序(即這里)。但我找不到的是如何按子類別之一對條形圖進(jìn)行排序。例如,給定以下數(shù)據(jù)框,我可以獲得條形圖。但是我想做的是將它從最大到最小排序,由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貢獻(xiàn)1797條經(jīng)驗 獲得超6個贊

添加order參數(shù)。使用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

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

TA貢獻(xiàn)1825條經(jīng)驗 獲得超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

查看完整回答
反對 回復(fù) 2021-12-21
  • 2 回答
  • 0 關(guān)注
  • 224 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號