美文网首页
python--pandas样式

python--pandas样式

作者: FTDdata | 来源:发表于2021-04-26 08:23 被阅读0次

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
1.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}')
2.png
  1. 对A列采用柱状图显示,正数为绿色,负数为红色,绝对值越大,柱越长。
  2. 对B列采用热力图显示。
  3. 对C列高亮缺失值。
  4. 对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()
3.png
# 高亮最小值
df.style.highlight_min(subset=['B','C','D'],color='green',axis=1)
4.png

highlight_null参数:

  • null_color:缺失值高亮的颜色
  • subset:数据框的切片,用来选择数据框的子集
# 高亮空值
df.style.highlight_null()
5.png

热力图

stylebackground_gradient方法用来显示表格热力图。

df.style.background_gradient()
6.png
# 使用不同的颜色地图
df.style.background_gradient(cmap='Accent')
7.png

条形图

stylebar方法用来增加表格内的条形图。

df.style.bar()
8.png

正、负数分开显示,设置alignmid,表示居中对齐,color参数第一个为负数颜色,
第二个为正数的颜色。

df.style.bar(align='mid',color=['#d65f5f', '#5fba7d'])
9.png

其他

# 保留2位小数,替换缺失值
df.style.format(formatter='{:.2f}',na_rep='FAIL')
10.png
# 设置标题
df.style.set_caption('table 1:demo table')
11.png
# 隐藏索引
df.style.hide_index()
12.png
# 隐藏列
df.style.hide_columns(subset=['A','B'])
13.png

相关文章

  • python--pandas样式

    pandas的DataFrame类拥有style属性,style属性返回Styler类,Styler类的apply...

  • python--pandas删除

    删除是数据清洗中的高频操作,本文基于pandas,介绍其dataFrame的一些删除操作,包括了删除行,删除列,删...

  • python--pandas切片

    pandas的切片操作是python中数据框的基本操作,用来选择数据框的子集。 环境 python3.9 win1...

  • python--pandas分组聚合

    分组聚合是数据处理中常见的场景,在pandas中用groupby方法实现分组操作,用agg方法实现聚合操作。 环境...

  • python--pandas读取excel

    对excel文件的读取是数据分析中常见的,在python中,pandas库的read_excel方法能够读取exc...

  • python--pandas长宽数据变形

    长型数据(long format dataframe)与宽型数据(wide format dataframe)是两...

  • python--pandas合并与连接

    合并与连接操作是数据处理中常见的,在pandas中用concat或append方法实现数据框的合并操作,用merg...

  • CSS-基础

    选择器样式:背景/大小样式:文本/字体 选择器 样式:背景/大小 样式:文本/字体 样式:边框 样式:内边距 样式...

  • CSS哪些样式属性可以继承

    不可继承的样式 可继承的样式 所有元素可继承: 内联样式: 块状样式: 列表样式: 表格样式:

  • iOS 改变字符串中所有指定字符串的颜色

    样式 代码 样式 代码 样式

网友评论

      本文标题:python--pandas样式

      本文链接:https://www.haomeiwen.com/subject/tgzlhltx.html