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

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

使用來自另一個數據框的值將熊貓條樣式應用于數據框

使用來自另一個數據框的值將熊貓條樣式應用于數據框

FFIVE 2022-12-20 12:16:28
我有 df1 和 df2。我想使用 df2 中的值在 df1 的單元格中顯示條形圖。我能夠使用下面的代碼應用其他形式的樣式,但是對于條形圖你不能使用這種方法。def color_cells(s):    if s > 90:        return 'color:{0}; font-weight:bold'.format('green')    elif s>80:        return 'background-color: light yellow;color:{0}; font-weight:regular'.format('dark yellow')    else:        return 'color:{0}; font-weight:bold'.format('red')df1.style.apply(lambda x: df2.applymap(color_cells), axis=None)我在 df2 中獲取條形碼的代碼是df2.style.bar(color=['#d65f5f', '#5fba7d'])如何將以上代碼應用于 df1?索引和列名相同。添加示例數據框:df1=pd.DataFrame(np.random.rand(15, 10))df2=pd.DataFrame(np.random.rand(15, 10)*100)
查看完整描述

1 回答

?
慕俠2389804

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

這是執行此操作的代碼:


df1=pd.DataFrame(np.random.rand(15, 10))

df2=pd.DataFrame(np.random.rand(15, 10)*100)


pct = (df2 - df2.min()) / (df2.max() - df2.min() )*100


def make_bar_style(x):

    return f"background: linear-gradient(90deg,#5fba7d {x}%, transparent {x}%); width: 10em"    

pct.applymap(make_bar_style).shape


df1.style.apply(lambda x: pct.applymap(make_bar_style), axis=None)

結果是:

http://img1.sycdn.imooc.com//63a13740000102b920000927.jpg

為了證明條形尺寸由 df2 驅動這一事實,請考慮以下內容:

df2 = pd.DataFrame(np.mgrid[0:15, 0:10][0])

結果是:

http://img1.sycdn.imooc.com//63a1374f0001232919910888.jpg

查看完整回答
反對 回復 2022-12-20
  • 1 回答
  • 0 關注
  • 124 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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