0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

pandas 8个常用的option设置

电子工程师 来源:Python数据科学 作者:东哥起飞 2022-08-05 11:17 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群


通过pandas的使用,我们经常要交互式地展示表格(dataframe)、分析表格。而表格的格式就显得尤为重要了,因为大部分时候如果我们直接展示表格,格式并不是很友好。

其实呢,这些痛点都可以通过pandasoption来解决。短短几行代码,只要提前配置好,一次设置好,全局生效,perfect!

#使用方法
importpandasaspd
pd.set_option()
pd.get_option()

#使用属性,例如展示的最大行数
pd.option.display.max_rows

东哥整理了8个常用的配置选项,供大家参考。记住这8个option代码,下次直接粘贴进去,效率可以提高很多,爽歪歪。

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

1. 显示更多行

默认情况下,pandas 是不超出屏幕的显示范围的,如果表的行数很多,它会截断中间的行只显示一部分。我们可以通过设置display.max_rows来控制显示的最大行数,比如我想设置显示200行。

pd.set_option('display.max_rows',200)
#pd.options.display.max_rows=200

如果行数超过了display.max_rows,那么display.min_rows将确定显示的部分有多少行。因为display.min_rows的默认行数为5,,下面例子只显示前5行和最后5行,中间的所有行省略。

44cd1f0c-146a-11ed-ba43-dac502259ad0.png

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

pd.set_option('display.min_rows',10)
#pd.options.display.min_rows=10

还可以直接重置。

#重置
pd.reset_option('display.max_rows')

2. 显示更多列

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

pd.get_option('display.max_columns')
#pd.options.display.max_columns
20
44d893f0-146a-11ed-ba43-dac502259ad0.png

3. 改变列宽

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

pd.set_option('display.max_colwidth',500)
#pd.options.display.max_colwidth=500
44f73b2a-146a-11ed-ba43-dac502259ad0.png

4. 设置float列的精度

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

pd.set_option('display.precision',2)
#pd.options.display.precision=2
45041494-146a-11ed-ba43-dac502259ad0.png

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

5. 数字格式化显示

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

用逗号格式化大值数字

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

pd.set_option('display.float_format','{:,}'.format)
4512d0f6-146a-11ed-ba43-dac502259ad0.png

设置数字精度

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

pd.set_option('display.float_format','{:,.2f}'.format)
452576ac-146a-11ed-ba43-dac502259ad0.png

百分号格式化

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

pd.set_option('display.float_format','{:.2f}%'.format)
454947d0-146a-11ed-ba43-dac502259ad0.png

或者其它币种的符号等均可,只需要在大括号{}前后添加即可。

6. 更改绘图方法

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

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

importpandasaspd
importnumpyasnp
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()
45639b44-146a-11ed-ba43-dac502259ad0.png

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

#具体的搜索
pd.describe_option('rows')
4588559c-146a-11ed-ba43-dac502259ad0.png

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

pd.reset_option('all')

以上就是8个常用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')#重置所有设置选项

审核编辑 :李倩


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 控制
    +关注

    关注

    5

    文章

    1035

    浏览量

    125849
  • 字符
    +关注

    关注

    0

    文章

    237

    浏览量

    26274
  • 代码
    +关注

    关注

    30

    文章

    4976

    浏览量

    74375

原文标题:好习惯!pandas 8 个常用的 option 设置

文章出处:【微信号:AI科技大本营,微信公众号:AI科技大本营】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    施耐德电气伺服驱动常用参数设置

    施耐德伺服驱动器的常用参数设置主要集中在 电子齿轮比 、 转矩/转速限制 和 基本增益调整 三方面。不同系列的参数地址和设置方法有所不同,以下按功能分类说明: 一、 电子齿轮比
    的头像 发表于 04-22 15:36 61次阅读
    施耐德电气伺服驱动<b class='flag-5'>常用</b>参数<b class='flag-5'>设置</b>

    变频器的常用参数调整

    变频器的调试通常遵循一套标准化的流程,最核心的原则是: 确保变频器认识电机(输入电机参数),然后告诉变频器如何控制和运行(设置命令与频率源) 。下面是从基础到进阶的常用参数调整指南。 第一步
    的头像 发表于 04-14 07:08 118次阅读
    变频器的<b class='flag-5'>常用</b>参数调整

    中颖电子8位单片机的I/O设置介绍

    在嵌入式系统设计中,单片机的I/O端口设置是基础且关键的一环。今天我们来详细解析中颖电子8位单片机的I/O设置,帮助工程师更好地理解和应用。
    的头像 发表于 12-30 09:37 883次阅读
    中颖电子<b class='flag-5'>8</b>位单片机的I/O<b class='flag-5'>设置</b>介绍

    瑞萨RL78F2x系列MCU在三种开发环境下的选项字节与安全ID设置方法

    在RL78F2x系列MCU的项目开发中,正确设置Option Byte(选项字节)和Security ID(安全ID)是保证芯片安全、配置工作模式(如看门狗、低电压检测、复位引脚等)的关键一步。面对
    的头像 发表于 12-11 16:33 4897次阅读
    瑞萨RL78F2x系列MCU在三种开发环境下的选项字节与安全ID<b class='flag-5'>设置</b>方法

    8常用的CRC算法分享

    CRC 计算单元可按所选择的算法和参数配置来生成数据流的 CRC 码。有些应用中,可利用 CRC 技术来验证数据的传输和存储的完整性。 8常用的 CRC 算法,包括: CRC16_IBM
    发表于 11-13 07:25

    使用jQuery的常用方法与返回值分析

    使用jQuery的常用方法与返回值分析 jQuery是一轻量级的JavaScript库,旨在简化HTML文档遍历和操作、事件处理以及动画效果的创建。本文将介绍一些常用的jQuery方法及其返回值
    发表于 10-01 20:18

    科普 | 5G接口管理--NG接口设置

    一、NG接口设置在5G中NG设置流程的目的是交换NG-RAN节点和AMF在NG-C接口上正确互操作所需的应用级数据。设置流程是TNL关联投入运行后触发的第一NGAP流程,使用非UE关
    的头像 发表于 09-29 15:17 1655次阅读
    科普 | 5G接口管理--NG接口<b class='flag-5'>设置</b>

    shell基本介绍及常用命令之shell基本介绍

    命令终止程序;8.命令及其参数区分大小写;无论我们使用哪种Shell,登陆系统后会生成一Shell进程,根据用户不同显示不同的提示符,root用户的通常提示符是“#”,普通用户的命令提示符
    发表于 09-28 09:05

    是德科技信号分析仪灵敏度的设置

    信号分析仪(也称为频谱分析仪)通常用于测量微弱信号,包括已知信号和未知信号。通过噪声校正、本底噪声扩展 (NFE) 和优化信号分析仪设置,可以实现设备的最佳灵敏度,从而更轻松地检测和测量微弱信号。
    的头像 发表于 08-21 09:30 2620次阅读
    是德科技信号分析仪灵敏度的<b class='flag-5'>设置</b>

    在ANSA中设置ABAQUS独立非线性分析步的方法

    搭建Abaqus有限元模型时,经常需要设置多分析步。在设置Abaqus多分析步的常用方法为在仿真分析任务中设置多个“Step”,将整个仿真任务的求解时间划分为若干个Step(图1),用
    的头像 发表于 08-06 15:14 1765次阅读
    在ANSA中<b class='flag-5'>设置</b>ABAQUS独立非线性分析步的方法

    如何使用WaveDac8设置简单的数据采集系统,以生成不同持续时间的脉冲?

    我目前正在尝试使用 WaveDac8 设置简单的数据采集系统,以生成不同持续时间的脉冲,并应用于 RC 简单电路。我成功生成了 250 采样脉冲,并用示波器验证了波形。我现在的挑
    发表于 07-25 07:55

    PLC数据采集平台需要设置哪些参数

    PLC数据采集平台的参数设置需围绕设备通信、数据采集规则、存储与处理、安全与告警等核心环节展开,确保数据准确、实时、可靠地传输与管理。以下是具体的参数分类及说明: 一、设备通信参数 用于建立PLC
    的头像 发表于 07-11 16:03 966次阅读

    Keysight是德示波器的5触发设置与波形分析方法

    Keysight是德示波器在电子测量领域应用广泛,精准的触发设置与高效的波形分析方法对获取准确信号信息至关重要。以下为您介绍5常用的触发设置及波形分析方法。   边沿触发
    的头像 发表于 06-27 16:00 1701次阅读
    Keysight是德示波器的5<b class='flag-5'>个</b>触发<b class='flag-5'>设置</b>与波形分析方法

    基于瑞萨电子RA8T2 sensorless方案的样例工程 可对电流环进行TCM化设置

    基于瑞萨电子RA8T2 sensorless方案的样例工程 可对电流环进行TCM化设置
    的头像 发表于 06-04 18:29 1250次阅读

    Docker Compose的常用命令

    大家好,今天给大家分享Docker Compose的常用命令,以及docker-compose文件的属性。Docker Compose 是一用于定义和运行多容器 Docker 应用应用的重要工具
    的头像 发表于 04-30 13:40 1388次阅读