• 数据科学家的经验,python中dataframe的最常用设置!


    好书推荐

    北大出版社,人工智能原理与实践 人工智能和数据科学从入门到精通 详解机器学习深度学习算法原理

    人工智能原理与实践 全面涵盖人工智能和数据科学各个重要体系经典

    数据科学家最常用的数据表格工具当属 pandas; 通过pandas表格,可以方便的展示表格(dataframe)和分析表格。而表格的格式设置不好,会影响分析效率。

    所谓磨刀不误砍柴工,工欲善其事必先利其器, 下面大家了解一下常用的几种设置方法:

    1. 显示更多行
    2. 显示更多列
    3. 改变列宽
    4. 设置float列的精度
    5. 数字格式化显示
    6. 更改绘图方法
    7. 配置info()的输出
    8. 打印出当前设置并重置所有选项

    1. 显示更多行

    默认设置,pandas 是不超出屏幕的显示范围的,如果表的行数很多,它会截断中间的行只显示一部分。有些时候,如果需要查看的数据的总行数不多,可以通过设置display.max_rows来控制显示的最大行数,比如设置显示200行数据,从而一次性查看数据:

    import pandas as pd
    pd.set_option('display.max_rows', 200)
    # 或者这样设置
    # pd.options.display.max_rows = 200
    
    • 1
    • 2
    • 3
    • 4

    但当数据的行数超过了display.max_rows,那么display.min_rows将确定显示的部分有多少行。因为display.min_rows的默认行数为10,因此数据一般显示为前5行数据,和后5行数据。

    同理,也可根据自己的习惯显示可显示的行数,比如20

    pd.set_option('display.min_rows', 20)
    # pd.options.display.min_rows = 20
    
    • 1
    • 2

    如果需要恢复默认的设置,可以这样重置为默认情况:

    # 重置
    pd.reset_option('display.max_rows')
    
    • 1
    • 2

    2. 显示更多列

    行可以设置,同样的列也可以设置,display.max_columns控制着可显示的列数,默认值为20。

    pd.get_option('display.max_columns') 
    # pd.options.display.max_columns
    20
    
    • 1
    • 2
    • 3

    3. 改变列宽

    pandas对列中显示的字符数有一些限制,默认值为50字符。所以,有的值字符过长就会显示省略号。如果想全部显示,可以设置display.max_colwidth,比如设置成500。

    pd.set_option ('display.max_colwidth',500)
    # pd.options.display.max_colwidth = 500
    
    • 1
    • 2

    4. 设置float列的精度

    对于float浮点型数据,pandas默认情况下只显示小数点后6位。我们可以通过预先设置display.precision让其只显示2位,避免后面重复操作。

    pd.set_option( 'display.precision',2)
    # pd.options.display.precision = 2
    
    • 1
    • 2

    这个设置不影响底层数据,它只影响浮动列的显示。

    5. 数字格式化显示

    pandas中有一个选项display.float_formatoption可以用来格式化任何浮点列。这个仅适用于浮点列,对于其他数据类型,必须将它们转换为浮点数才可以。

    用逗号格式化大值数字

    例如 1200000 这样的大数字看起来很不方便,所以我们用逗号进行分隔。

    pd.set_option('display.float_format','{:,}'.format)
    
    • 1

    在这里插入图片描述

    设置数字精度

    和上面display.precision有点类似,假如我们只关心小数点后的2位数字,我们可以这样设置格式化:

    pd.set_option('display.float_format',  '{:,.2f}'.format)
    
    • 1

    百分号格式化

    如果我们要显示一个百分比的列,可以这样设置。

    pd.set_option('display.float_format', '{:.2f}%'.format)
    
    • 1

    6. 更改绘图方法

    默认情况下,pandas使用matplotlib作为绘图后端。从 0.25 版本开始,pandas提供了使用不同后端选择,比如plotly,bokeh等第三方库,但前提是你需要先安装起来。

    设置很简单,只要安装好三方库后,同样只需要一行。

    import pandas as pd
    import numpy as np
    pd.set_option('plotting.backend', 'altair')
    data = pd.Series(np.random.randn(100).cumsum())
    data.plot()
    
    • 1
    • 2
    • 3
    • 4
    • 5

    7. 配置info()的输出

    pandas中我们经常要使用info()来快速查看DataFrame的数据情况。但是,info这个方法对要分析的最大列数是有默认限制的,并且如果数据集中有null,那么在大数据集计数统计时会非常慢。

    pandas提供了两种选择:

    display.max_info_columns: 设置要分析的最大列数,默认为100。
    display.max_info_rows: 设置计数null时的阈值,默认为1690785。
    
    • 1
    • 2

    比如,在分析有 150 个特征的数据集时,我们可以设置display.max_info_columns为涵盖所有列的值,比如将其设置为 200:

    pd.set_option('display.max_info_columns', 200)
    
    • 1

    在分析大型数据集时,df.info()由于要计算所有null,导致速度很慢。因此我们可以简单地设置display.max_info_rows为一个小的值来避免计数,例如只在行数不超过5时才计数null:

    pd.set_option('display.max_info_rows', 5)
    
    • 1

    8. 打印出当前设置并重置所有选项

    pd.describe_option()将打印出设置的描述及其当前值。

    pd.describe_option()
    
    • 1

    还可以打印特定的选项,例如,行显示。

    # 具体的搜索
    pd.describe_option('rows')
    
    • 1
    • 2

    最后,我们还可以直接全部重置。

    pd.reset_option('all')
    
    • 1

    总结

    以上就是常用set_option的使用,大家可以一次性设置如下:

    pd.set_option('display.max_rows',xxx) # 最大行数
    pd.set_option('display.min_rows',xxx) # 最小显示行数
    pd.set_option('display.max_columns',xxx) # 最大显示列数
    pd.set_option ('display.max_colwidth',xxx) #最大列字符数
    pd.set_option( 'display.precision',2) # 浮点型精度
    pd.set_option('display.float_format','{:,}'.format) #逗号分隔数字
    pd.set_option('display.float_format',  '{:,.2f}'.format) #设置浮点精度
    pd.set_option('display.float_format', '{:.2f}%'.format) #百分号格式化
    pd.set_option('plotting.backend', 'altair') # 更改后端绘图方式
    pd.set_option('display.max_info_columns', 200) # info输出最大列数
    pd.set_option('display.max_info_rows', 5) # info计数null时的阈值
    pd.describe_option() #展示所有设置和描述
    pd.reset_option('all') #重置所有设置选项
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    好书推荐

    北大出版社,人工智能原理与实践 人工智能和数据科学从入门到精通 详解机器学习深度学习算法原理

    人工智能原理与实践 全面涵盖人工智能和数据科学各个重要体系经典

    英文链接
    datasciencebyexample

  • 相关阅读:
    Docker通信全视角:原理、实践与技术洞察
    旅游网站毕业设计,旅游网站网页设计设计源码,旅游网站设计毕业论文
    Vue项目实战之电商后台管理系统(五) 商品分类模块
    云原生时代崛起的编程语言Go基础实战
    AlGaN/GaN HEMT 中缓冲区相关电流崩溃的缓冲区电位模拟表征
    2022年全网最全的Oracle数据库技术附练习题以及答案 循序渐进
    基于PYTHON游乐场服务管理系统的设计与实现
    电商数据|淘宝商品数据接口接入|参数|获取商品订单物流|电商数据分析
    初级CRUD程序员 打工人流程规范
    生产事故-走近科学之消失的JWT
  • 原文地址:https://blog.csdn.net/robot_learner/article/details/126205217