pandas的DataFrame类拥有style属性,style属性返回Styler类,
Styler类的applymap和apply等方法可以很方便的对表格样式做自定义调整。
环境
- python3.9
- win10 64bit
- pandas==1.2.1
快速了解
先通过一个实例快速了解style的设置方法和效果。
import pandas as pd
import numpy as np
# 构造数据框
np.random.seed(24)
df = pd.DataFrame(np.random.randn(6, 4), columns=list('ABCD'))
df.iloc[3, 3] = np.nan
df.iloc[0, 2] = np.nan
df
![](https://img.haomeiwen.com/i20787660/deb7daf4d0747179.png)
自定义一个样式函数,用来格式化显示表格中的元素。
def style_func(x)->str:
# 元素颜色
color='red' if x>0 else ''
# 元素字体
weight='bold' if x>0 else 'normal'
# 返回样式
return ';'.join([f'color:{color}',f'font-weight:{weight}'])
对数据框的元素组合应用样式函数。
df.style.bar(subset=['A'],align='mid',color=['#d65f5f', '#5fba7d']).\
background_gradient(subset=['B']).\
highlight_null(subset=['C']).\
applymap(style_func,subset=['D']).\
format('{:.2f}')
![](https://img.haomeiwen.com/i20787660/6e0cd66e374b162c.png)
- 对A列采用柱状图显示,正数为绿色,负数为红色,绝对值越大,柱越长。
- 对B列采用热力图显示。
- 对C列高亮缺失值。
- 对D列应用自定义样式函数,红色加粗显示正数。
样式函数
样式函数的定义是基于CSS的,函数返回值必须是CSS格式的字符串,用;
分割不同属性,
每种属性用key:value
形式表示。CSS样式设置可参考CSS样式 。
高亮
style
自带三种高亮方法,highlight_max
,highlight_min
,highlight_null
可分别高亮最大值,
最小值,空置。
highlight_max/highlight_min参数:
-
subset
:数据框的切片,用来选择数据框的子集 -
color
:高亮的颜色 -
axis
:应用数据框的行(1)或列(0)或全部(None)
# 高亮最大值
df.style.highlight_max()
![](https://img.haomeiwen.com/i20787660/a83678ccd37c3e17.png)
# 高亮最小值
df.style.highlight_min(subset=['B','C','D'],color='green',axis=1)
![](https://img.haomeiwen.com/i20787660/85e539b3a32cec66.png)
highlight_null参数:
-
null_color
:缺失值高亮的颜色 -
subset
:数据框的切片,用来选择数据框的子集
# 高亮空值
df.style.highlight_null()
![](https://img.haomeiwen.com/i20787660/7274c55b3857a06c.png)
热力图
style
的background_gradient
方法用来显示表格热力图。
df.style.background_gradient()
![](https://img.haomeiwen.com/i20787660/a6c475ef930da4b1.png)
# 使用不同的颜色地图
df.style.background_gradient(cmap='Accent')
![](https://img.haomeiwen.com/i20787660/7a9cc89f54e7a851.png)
条形图
style
的bar
方法用来增加表格内的条形图。
df.style.bar()
![](https://img.haomeiwen.com/i20787660/5ae6201fabfb94f9.png)
正、负数分开显示,设置align
为mid
,表示居中对齐,color
参数第一个为负数颜色,
第二个为正数的颜色。
df.style.bar(align='mid',color=['#d65f5f', '#5fba7d'])
![](https://img.haomeiwen.com/i20787660/baad31de13959fae.png)
其他
# 保留2位小数,替换缺失值
df.style.format(formatter='{:.2f}',na_rep='FAIL')
![](https://img.haomeiwen.com/i20787660/07d82630a9c01235.png)
# 设置标题
df.style.set_caption('table 1:demo table')
![](https://img.haomeiwen.com/i20787660/78d156883b8ee14b.png)
# 隐藏索引
df.style.hide_index()
![](https://img.haomeiwen.com/i20787660/9c0b49e69192b147.png)
# 隐藏列
df.style.hide_columns(subset=['A','B'])
![](https://img.haomeiwen.com/i20787660/b6a4516513de34b2.png)
网友评论