<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
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提供了使用不同后端選擇,比如plotly,bokeh等第三方庫,但前提是你需要先安裝起來。

設置很簡單,只要安裝好三方庫后,同樣只需要一行。

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')#重置所有設置選項

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 控制
    +關注

    關注

    4

    文章

    998

    瀏覽量

    122294
  • 字符
    +關注

    關注

    0

    文章

    229

    瀏覽量

    24976
  • 代碼
    +關注

    關注

    30

    文章

    4575

    瀏覽量

    67133

原文標題:好習慣!pandas 8 個常用的 option 設置

文章出處:【微信號:AI科技大本營,微信公眾號:AI科技大本營】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    STVP中stm8af6226的Option bytes與Datasheet不符是為什么?

    與stm8af6246的Option bytes相同,是STVP不支持stm8af6226嗎?難道只能在程序里設置Option bytes了
    發表于 05-09 08:22

    stm8如果使用到多功能引腳,用stvd調試仿真的時候,是否還需要設置option byte 來使功能正常使用?

    各位前輩,請問一下如果使用到多功能引腳,其中的一功能比如tim2_ch1 。用stvd調試仿真的時候,是否還需要設置option byte 來使功能正常使用。 我記得用stvp下載程序的時候需要
    發表于 05-08 07:23

    IAR for STM8工程-&gt;option選項中ST-Link各個選項是什么意思?

    Fri Jul 13, 2018 08:55:37: Errors while setting configuration with MCU name STM8S103K3: gdi-error
    發表于 04-28 06:57

    STM8L051的LSI設置,用IAR沒法在option byte設置LSI-EN怎么解決?

    option byte里面沒有LSI-EN選項,是軟件問題還是這個芯片有什么制約?我想用LSI作為系統時鐘該怎么設置?
    發表于 04-26 07:26

    Python利用pandas讀寫Excel文件

    使用pandas模塊讀取Excel文件可以更為方便和快捷。pandas可以將Excel文件讀取為一個DataFrame對象,方便進行數據處理和分析。
    的頭像 發表于 12-16 11:22 ?693次閱讀
    Python利用<b class='flag-5'>pandas</b>讀寫Excel文件

    Pandas:Python中強大方便的繪圖功能

    Pandas是Python中非常常用的數據處理工具,使用起來非常方便。由于建立在NumPy數組結構之上,所以它的很多操作通過NumPy或者Pandas自帶的擴展模塊編寫,這些模塊用Cython編寫
    的頭像 發表于 11-03 11:04 ?312次閱讀
    <b class='flag-5'>Pandas</b>:Python中強大方便的繪圖功能

    STM8S配置字節OPTION BYTE

    用戶必須在這兩功能中選擇一,只能選擇一。那如何使PD4是BEEP輸出呢?答案是通過設置Option byte 選項字,將AFR7配置成
    發表于 10-10 06:07

    STM8S的配置字節Option Byte

    電子發燒友網站提供《STM8S的配置字節Option Byte.pdf》資料免費下載
    發表于 10-07 16:12 ?0次下載
    STM8S的配置字節<b class='flag-5'>Option</b> Byte

    在 KEIL 中通過 opt.s 文件設置 Option Bytes

    在 KEIL 中通過 opt.s 文件設置 Option Bytes
    的頭像 發表于 09-28 17:30 ?848次閱讀
    在 KEIL 中通過 opt.s 文件<b class='flag-5'>設置</b> <b class='flag-5'>Option</b> Bytes

    Option的基礎用法

    Option 是 Rust 語言中的一個枚舉類型,它表示一個值可能存在,也可能不存在的情況。Option 可以理解為一個容器,它可能裝有一個值,也可能為空。在 Rust 中,Option 可以用
    的頭像 發表于 09-20 11:07 ?1622次閱讀

    如何使用Python和pandas庫讀取、寫入文件

    在本文中,我將介紹如何使用 Python 和 pandas 庫讀取、寫入文件。 1、安裝 pip install pandas 2、讀取 import pandas as pd df
    的頭像 發表于 09-11 17:52 ?828次閱讀

    超強圖解Pandas,建議收藏

    Pandas是數據挖掘常見的工具,掌握使用過程中的函數是非常重要的。本文將借助可視化的過程,講解Pandas的各種操作。
    的頭像 發表于 08-29 15:15 ?410次閱讀
    超強圖解<b class='flag-5'>Pandas</b>,建議收藏

    使用手冊 Cloud Option Board

    使用手冊 Cloud Option Board
    發表于 07-05 20:33 ?0次下載
    使用手冊 Cloud <b class='flag-5'>Option</b> Board

    原理圖 Cloud Option Board

    原理圖 Cloud Option Board
    發表于 07-05 20:18 ?0次下載
    原理圖 Cloud <b class='flag-5'>Option</b> Board

    Pandas高級操作匯總

    ? 今天給大家分享一篇Pandas高級操作匯總~ ? 在數據分析和數據建模的過程中需要對數據進行清洗和整理等工作,有時需要對數據增刪字段。下面為大家介紹Pandas對數據的復雜查詢、數據類型轉換
    的頭像 發表于 06-16 10:27 ?279次閱讀
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>