0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

pandas 8個(gè)常用的option設(shè)置

電子工程師 ? 來(lái)源:Python數(shù)據(jù)科學(xué) ? 作者:東哥起飛 ? 2022-08-05 11:17 ? 次閱讀

通過(guò)pandas的使用,我們經(jīng)常要交互式地展示表格(dataframe)、分析表格。而表格的格式就顯得尤為重要了,因?yàn)榇蟛糠謺r(shí)候如果我們直接展示表格,格式并不是很友好。

其實(shí)呢,這些痛點(diǎn)都可以通過(guò)pandasoption來(lái)解決。短短幾行代碼,只要提前配置好,一次設(shè)置好,全局生效,perfect!

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

#使用屬性,例如展示的最大行數(shù)
pd.option.display.max_rows

東哥整理了8個(gè)常用的配置選項(xiàng),供大家參考。記住這8個(gè)option代碼,下次直接粘貼進(jìn)去,效率可以提高很多,爽歪歪。

  • 顯示更多行
  • 顯示更多列
  • 改變列寬
  • 設(shè)置float列的精度
  • 數(shù)字格式化顯示
  • 更改繪圖方法
  • 配置info()的輸出
  • 打印出當(dāng)前設(shè)置并重置所有選項(xiàng)

1. 顯示更多行

默認(rèn)情況下,pandas 是不超出屏幕的顯示范圍的,如果表的行數(shù)很多,它會(huì)截?cái)嘀虚g的行只顯示一部分。我們可以通過(guò)設(shè)置display.max_rows來(lái)控制顯示的最大行數(shù),比如我想設(shè)置顯示200行。

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

如果行數(shù)超過(guò)了display.max_rows,那么display.min_rows將確定顯示的部分有多少行。因?yàn)?code style="padding:2px 4px;margin-right:2px;margin-left:2px;background-color:rgba(27,31,35,.05);font-family:'Operator Mono', Consolas, Monaco, Menlo, monospace;color:rgb(89,89,89);font-size:13px;letter-spacing:.5px;">display.min_rows的默認(rèn)行數(shù)為5,,下面例子只顯示前5行和最后5行,中間的所有行省略。

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

同理,也可根據(jù)自己的習(xí)慣顯示可顯示的行數(shù),比如10, 20..

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

還可以直接重置。

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

2. 顯示更多列

行可以設(shè)置,同樣的列也可以設(shè)置,display.max_columns控制著可顯示的列數(shù),默認(rèn)值為20。

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

3. 改變列寬

pandas對(duì)列中顯示的字符數(shù)有一些限制,默認(rèn)值為50字符。所以,有的值字符過(guò)長(zhǎng)就會(huì)顯示省略號(hào)。如果想全部顯示,可以設(shè)置display.max_colwidth,比如設(shè)置成500。

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

4. 設(shè)置float列的精度

對(duì)于float浮點(diǎn)型數(shù)據(jù),pandas默認(rèn)情況下只顯示小數(shù)點(diǎn)后6位。我們可以通過(guò)預(yù)先設(shè)置display.precision讓其只顯示2位,避免后面重復(fù)操作。

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

這個(gè)設(shè)置不影響底層數(shù)據(jù),它只影響浮動(dòng)列的顯示。

5. 數(shù)字格式化顯示

pandas中有一個(gè)選項(xiàng)display.float_formatoption可以用來(lái)格式化任何浮點(diǎn)列。這個(gè)僅適用于浮點(diǎn)列,對(duì)于其他數(shù)據(jù)類型,必須將它們轉(zhuǎn)換為浮點(diǎn)數(shù)才可以。

用逗號(hào)格式化大值數(shù)字

例如 1200000 這樣的大數(shù)字看起來(lái)很不方便,所以我們用逗號(hào)進(jìn)行分隔。

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

設(shè)置數(shù)字精度

和上面display.precision有點(diǎn)類似,假如我們只關(guān)心小數(shù)點(diǎn)后的2位數(shù)字,我們可以這樣設(shè)置格式化:

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

百分號(hào)格式化

如果我們要顯示一個(gè)百分比的列,可以這樣設(shè)置。

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

或者其它幣種的符號(hào)等均可,只需要在大括號(hào){}前后添加即可。

6. 更改繪圖方法

默認(rèn)情況下,pandas使用matplotlib作為繪圖后端。從 0.25 版本開(kāi)始,pandas提供了使用不同后端選擇,比如plotly,bokeh等第三方庫(kù),但前提是你需要先安裝起來(lái)。

設(shè)置很簡(jiǎn)單,只要安裝好三方庫(kù)后,同樣只需要一行。

importpandasaspd
importnumpyasnp
pd.set_option('plotting.backend','altair')
data=pd.Series(np.random.randn(100).cumsum())
data.plot()

7. 配置info()的輸出

pandas中我們經(jīng)常要使用info()來(lái)快速查看DataFrame的數(shù)據(jù)情況。但是,info這個(gè)方法對(duì)要分析的最大列數(shù)是有默認(rèn)限制的,并且如果數(shù)據(jù)集中有null,那么在大數(shù)據(jù)集計(jì)數(shù)統(tǒng)計(jì)時(shí)會(huì)非常慢。

pandas提供了兩種選擇:

  • display.max_info_columns: 設(shè)置要分析的最大列數(shù),默認(rèn)為100。
  • display.max_info_rows: 設(shè)置計(jì)數(shù)null時(shí)的閾值,默認(rèn)為1690785。

比如,在分析有 150 個(gè)特征的數(shù)據(jù)集時(shí),我們可以設(shè)置display.max_info_columns為涵蓋所有列的值,比如將其設(shè)置為 200:

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

在分析大型數(shù)據(jù)集時(shí),df.info()由于要計(jì)算所有null,導(dǎo)致速度很慢。因此我們可以簡(jiǎn)單地設(shè)置display.max_info_rows為一個(gè)小的值來(lái)避免計(jì)數(shù),例如只在行數(shù)不超過(guò)5時(shí)才計(jì)數(shù)null

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

8. 打印出當(dāng)前設(shè)置并重置所有選項(xiàng)

pd.describe_option()將打印出設(shè)置的描述及其當(dāng)前值。

pd.describe_option()
45639b44-146a-11ed-ba43-dac502259ad0.png

還可以打印特定的選項(xiàng),例如,行顯示。

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

最后,我們還可以直接全部重置。

pd.reset_option('all')

以上就是8個(gè)常用set_option的使用,下面進(jìn)行了匯總,方便大家粘貼使用。

pd.set_option('display.max_rows',xxx)#最大行數(shù)
pd.set_option('display.min_rows',xxx)#最小顯示行數(shù)
pd.set_option('display.max_columns',xxx)#最大顯示列數(shù)
pd.set_option('display.max_colwidth',xxx)#最大列字符數(shù)
pd.set_option('display.precision',2)#浮點(diǎn)型精度
pd.set_option('display.float_format','{:,}'.format)#逗號(hào)分隔數(shù)字
pd.set_option('display.float_format','{:,.2f}'.format)#設(shè)置浮點(diǎn)精度
pd.set_option('display.float_format','{:.2f}%'.format)#百分號(hào)格式化
pd.set_option('plotting.backend','altair')#更改后端繪圖方式
pd.set_option('display.max_info_columns',200)#info輸出最大列數(shù)
pd.set_option('display.max_info_rows',5)#info計(jì)數(shù)null時(shí)的閾值
pd.describe_option()#展示所有設(shè)置和描述
pd.reset_option('all')#重置所有設(shè)置選項(xiàng)

審核編輯 :李倩


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 控制
    +關(guān)注

    關(guān)注

    4

    文章

    1011

    瀏覽量

    122666
  • 字符
    +關(guān)注

    關(guān)注

    0

    文章

    233

    瀏覽量

    25208
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4788

    瀏覽量

    68611

原文標(biāo)題:好習(xí)慣!pandas 8 個(gè)常用的 option 設(shè)置

文章出處:【微信號(hào):AI科技大本營(yíng),微信公眾號(hào):AI科技大本營(yíng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    AFE5803 SPI是如何控制VCAT的,8路VCAT是只能設(shè)置同一個(gè)放大倍數(shù)還是可以設(shè)置8路不同的放大倍數(shù)?

    在datasheet中SPI Logic可以控制VCAT,但又沒(méi)有找到digital VCNTL mode,請(qǐng)問(wèn)SPI是如何控制VCAT的,8路VCAT是只能設(shè)置同一個(gè)放大倍數(shù)還是可以設(shè)置
    發(fā)表于 12-20 11:27

    RAPIDS cuDF將pandas提速近150倍

    在 NVIDIA GTC 2024 上,NVIDIA 宣布,RAPIDS cuDF 當(dāng)前已能夠?yàn)?950 萬(wàn) pandas 用戶帶來(lái) GPU 加速,且無(wú)需修改代碼。
    的頭像 發(fā)表于 11-20 09:52 ?176次閱讀
    RAPIDS cuDF將<b class='flag-5'>pandas</b>提速近150倍

    ad如何設(shè)置個(gè)元器件的距離

    在Altium Designer(簡(jiǎn)稱AD)中設(shè)置個(gè)元器件之間的距離,主要是通過(guò)設(shè)置元器件間的安全間距(Clearance)規(guī)則來(lái)實(shí)現(xiàn)的。這個(gè)規(guī)則定義了元器件之間、元器件與走線之間以及其他設(shè)計(jì)元素
    的頭像 發(fā)表于 09-02 15:31 ?7057次閱讀

    STM8蜂鳴器不響的原因?

    我做一個(gè)項(xiàng)目用到蜂鳴器,參考風(fēng)馳電子的教程寫了程序發(fā)現(xiàn)蜂鳴器不響,請(qǐng)大家指教? beepPwrOn(); uint16_t Beep_Option_status;/*記錄激活備選功能Beep
    發(fā)表于 05-10 07:16

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

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

    stm8如果使用到多功能引腳,用stvd調(diào)試仿真的時(shí)候,是否還需要設(shè)置option byte 來(lái)使功能正常使用?

    各位前輩,請(qǐng)問(wèn)一下如果使用到多功能引腳,其中的一個(gè)功能比如tim2_ch1 。用stvd調(diào)試仿真的時(shí)候,是否還需要設(shè)置option byte 來(lái)使功能正常使用。 我記得用stvp下載程序的時(shí)候需要
    發(fā)表于 05-08 07:23

    visual programmer軟件里面有個(gè)option Byte字節(jié)是什么含義?

    1、st visual programmer 軟件里面有個(gè)option Byte 字節(jié)是什么含義?2、工具欄上面6個(gè)編程用的按鈕,such as “read current tab
    發(fā)表于 04-28 08:34

    IAR for STM8工程-&gt;option選項(xiàng)中ST-Link各個(gè)選項(xiàng)是什么意思?

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

    STM8S103K3 option配置target下面有code和Data,這兩個(gè)的模式應(yīng)該怎么選擇?

    STM8S103K3option配置問(wèn)題 target下面有code 和 Data ,這兩個(gè)的模式應(yīng)該怎么選擇?在code =small, Data = medium 下,使用庫(kù)函數(shù)寫了一個(gè)串口發(fā)送
    發(fā)表于 04-28 06:24

    STM8L051的LSI設(shè)置,用IAR沒(méi)法在option byte設(shè)置LSI-EN怎么解決?

    option byte里面沒(méi)有LSI-EN選項(xiàng),是軟件問(wèn)題還是這個(gè)芯片有什么制約?我想用LSI作為系統(tǒng)時(shí)鐘該怎么設(shè)置
    發(fā)表于 04-26 07:26

    使用IAR和STlink,stm8 so disco的板子,提示Failed to set option byte: 怎么解決?

    使用IAR和STlink,stm8 so disco的板子,提示 Failed to set option byte: 寫保護(hù)應(yīng)該是取消了的,有沒(méi)有前輩遇到這個(gè)問(wèn)題
    發(fā)表于 04-16 08:03

    變頻器常用參數(shù)設(shè)置技巧與指南

    在實(shí)際設(shè)置時(shí),可能從中間某一步開(kāi)始。若還有其它的參數(shù)需要設(shè)置,不需要返回到待機(jī)狀態(tài),只要返回到相應(yīng)的一級(jí)繼續(xù)設(shè)置即可。全部參數(shù)設(shè)置完畢需要返回到待機(jī)狀態(tài)準(zhǔn)備開(kāi)車。有些參數(shù)還可以在變頻器
    發(fā)表于 04-05 09:32 ?3350次閱讀
    變頻器<b class='flag-5'>常用</b>參數(shù)<b class='flag-5'>設(shè)置</b>技巧與指南

    步進(jìn)驅(qū)動(dòng)器8位撥碼開(kāi)關(guān)設(shè)置

    了解8位撥碼開(kāi)關(guān)的結(jié)構(gòu)和工作原理。8位撥碼開(kāi)關(guān)通常由8個(gè)開(kāi)關(guān)按鈕組成,每個(gè)按鈕都有兩個(gè)狀態(tài):開(kāi)和關(guān)。開(kāi)關(guān)按鈕的位置決定了對(duì)應(yīng)的二進(jìn)制位的數(shù)值
    的頭像 發(fā)表于 01-16 10:29 ?6833次閱讀

    默認(rèn)usb設(shè)置怎么設(shè)置都表示什么

    USB(Universal Serial Bus)是一種常用的外部設(shè)備連接接口,在計(jì)算機(jī)和其他外部設(shè)備(如打印機(jī)、鍵盤、鼠標(biāo)、攝像頭等)之間進(jìn)行數(shù)據(jù)傳輸和電力供應(yīng)。USB接口的標(biāo)準(zhǔn)設(shè)置有四種,分別
    的頭像 發(fā)表于 01-03 17:56 ?4806次閱讀

    變頻器的常用參數(shù)設(shè)置

    變頻器作為現(xiàn)代工業(yè)控制的核心設(shè)備,其參數(shù)設(shè)置對(duì)于設(shè)備的正常運(yùn)行和性能至關(guān)重要。本文將詳細(xì)介紹變頻器的常用參數(shù)設(shè)置,包括基本參數(shù)、控制模式、輸出頻率、加速和減速時(shí)間等,并提供實(shí)際應(yīng)用中的指導(dǎo)原則,旨在幫助用戶合理配置參數(shù),確保變頻
    的頭像 發(fā)表于 12-29 09:27 ?3852次閱讀