python里dataframe怎么设置刻度

默认设置,pandas 是不超出屏幕的显示范围的,如果表的行数很多,它会截断中间的行只显示一部分。有些时候,如果需要查看的数据的总行数不多,可以通过设置display.max_rows来控制显示的最大行数,比如设置显示200行数据,从而一次性查看数据:import pandas as pd pd.set_option('display.max_rows', ...
python里dataframe怎么设置刻度
人工智能原理与实践 全面涵盖人工智能和数据科学各个重要体系经典
数据科学家最常用的数据表格工具当属 pandas; 通过pandas表格,可以方便的展示表格(dataframe)和分析表格。而表格的格式设置不好,会影响分析效率。

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

显示更多行
显示更多列
改变列宽
设置float列的精度
数字格式化显示
更改绘图方法
配置info()的输出
打印出当前设置并重置所有选项
1. 显示更多行
默认设置,pandas 是不超出屏幕的显示范围的,如果表的行数很多,它会截断中间的行只显示一部分。有些时候,如果需要查看的数据的总行数不多,可以通过设置display.max_rows来控制显示的最大行数,比如设置显示200行数据,从而一次性查看数据:

import pandas as pd
pd.set_option('display.max_rows', 200)
# 或者这样设置
# pd.options.display.max_rows = 200
登录后复制
但当数据的行数超过了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
登录后复制
如果需要恢复默认的设置,可以这样重置为默认情况:

# 重置
pd.reset_option('display.max_rows')
登录后复制
2. 显示更多列
行可以设置,同样的列也可以设置,display.max_columns控制着可显示的列数,默认值为20。

pd.get_option('display.max_columns')
# pd.options.display.max_columns
20
登录后复制
3. 改变列宽
pandas对列中显示的字符数有一些限制,默认值为50字符。所以,有的值字符过长就会显示省略号。如果想全部显示,可以设置display.max_colwidth,比如设置成500。

pd.set_option ('display.max_colwidth',500)
# pd.options.display.max_colwidth = 500
登录后复制
4. 设置float列的精度
对于float浮点型数据,pandas默认情况下只显示小数点后6位。我们可以通过预先设置display.precision让其只显示2位,避免后面重复操作。

pd.set_option( 'display.precision',2)
# pd.options.display.precision = 2
登录后复制
这个设置不影响底层数据,它只影响浮动列的显示。

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

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

pd.set_option('display.float_format','{:,}'.format)
登录后复制
设置数字精度
和上面display.precision有点类似,假如我们只关心小数点后的2位数字,我们可以这样设置格式化:

pd.set_option('display.float_format', '{:,.2f}'.format)
登录后复制
百分号格式化
如果我们要显示一个百分比的列,可以这样设置。

pd.set_option('display.float_format', '{:.2f}%'.format)
登录后复制
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()
登录后复制
7. 配置info()的输出
pandas中我们经常要使用info()来快速查看DataFrame的数据情况。但是,info这个方法对要分析的最大列数是有默认限制的,并且如果数据集中有null,那么在大数据集计数统计时会非常慢。

pandas提供了两种选择:

display.max_info_columns: 设置要分析的最大列数,默认为100。
display.max_info_rows: 设置计数null时的阈值,默认为1690785。
登录后复制
比如,在分析有 150 个特征的数据集时,我们可以设置display.max_info_columns为涵盖所有列的值,比如将其设置为 200:

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

pd.set_option('display.max_info_rows', 5)
登录后复制
8. 打印出当前设置并重置所有选项
pd.describe_option()将打印出设置的描述及其当前值。

pd.describe_option()
登录后复制
还可以打印特定的选项,例如,行显示。

# 具体的搜索
pd.describe_option('rows')
登录后复制
最后,我们还可以直接全部重置。

pd.reset_option('all')
登录后复制
总结
以上就是常用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') #重置所有设置选项
登录后复制2022-12-15
mengvlog 阅读 6 次 更新于 2025-07-19 20:00:07 我来答关注问题0
  •  文暄生活科普 python如何将两个dataframe根据多个条件进行合并?

    方法一:创建空的DataFrame 通过调用DataFrame构造函数可以创建一个基本的空DataFrame。方法二:使用List创建DataFrame 可以使用单个列表或列表的列表来创建DataFrame。方法三:使用字典创建DataFrame 使用字典创建DataFrame时,ndarray/lists作为字典的键,所有ndarray必须具有相同长度。默认情况下,索引为范围(n),...

  •  文暄生活科普 Python DataFrame 修改列名

    在Python的Pandas库中,对DataFrame列名的调整是常见且灵活的操作。这里有四种不同的方法来实现:方法一:列名全局替换 为了替换所有列名,可以直接将包含新名称的列表赋值给DataFrame的columns属性。方法二:选择性改名 对于部分列名的修改,你可以利用rename方法。这种方法会返回一个新的DataFrame,原始DataFrame...

  •  文暄生活科普 python中series转dataframe的两种方法

    方法一:使用to_frame()函数后,接着通过转置index与columns,从而实现Series转换为DataFrame。方法二:首先将Series转为字典,之后将其转为list,最后转换为DataFrame。因此,无论是通过使用to_frame()函数配合转置操作,还是经过字典、list到DataFrame的转换流程,都能够顺利完成Series到DataFrame的转换任务。请...

  •  翡希信息咨询 Python DataFrame 中选取数据及数据赋值方法( iloc 与loc的区别)

    在Python DataFrame中,数据选取和赋值的方法主要包括df.at, df.iloc[]和df.loc[],其中iloc与loc的区别如下:df.iloc[]: 功能:提供基于整数位置的索引来选取数据。 参数:接受行和列的整数位置索引,或者布尔索引。 使用示例: df.iloc[2]:获取第3行的数据。 df.iloc[[2,4]]:选取第...

  •  翡希信息咨询 pythonpandas里的dataframe报typeerror:unhashabletype

    在Python的Pandas库中,出现“TypeError: unhashable type”错误通常意味着你试图使用不可哈希的类型作为DataFrame的索引或列名。详细解释如下:理解不可哈希类型:在Python中,为了被哈希,一个对象必须是不可变的,并且能够提供唯一的哈希值。某些数据类型是可哈希的,而列表、集合和字典等复合数据类型则不可...

檬味博客在线解答立即免费咨询

Python相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部