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

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

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

Python官方竟然給出了一種編碼規(guī)范PEP 8

電子工程師 ? 來源:lq ? 2019-01-02 10:24 ? 次閱讀

寫在之前

每個人都有自己的代碼風(fēng)格,隨著寫的行數(shù)增加,自己對于代碼的審美也會變的不一樣,這就像是一個逐漸蛻變的過程,每過一段時間回頭再去看看自己之前寫的代碼就會生出一種「這么丑的玩意兒竟然是我寫的」這種感慨。

之前不論是寫 C 或者是 C++ 的時候,對于代碼風(fēng)格的好壞觀感完全是憑著自己的主觀意識,也沒有什么官方標準說這樣那樣就是好看的。等學(xué)了 Python 以后,神奇的發(fā)現(xiàn) Python 官方竟然給出了一種編碼規(guī)范 PEP 8,當然這個只是個標準而已,并沒有強制要求大家都要去遵守,但又好像大多數(shù)人都使用了 PEP 8 編碼風(fēng)格,使它已經(jīng)成為了事實上的代碼風(fēng)格標準。

PEP 8 編碼規(guī)范

Python 代碼從第一眼看上去,給人的感覺就是簡潔優(yōu)美,可讀性強,也就是我們?nèi)粘Kf的「高顏值」。一方面是因為 Python 自身的優(yōu)秀設(shè)計,比如統(tǒng)一的鎖進,沒有多余的符號從而讓代碼變的更加簡潔;另一方面就是因為它有著一套較為統(tǒng)一的編碼風(fēng)格,當然它本身只是編碼風(fēng)格方面的建議而不是強制,相應(yīng)的在編寫 Python 代碼的編輯器自動提供 PFP 8 檢查,當你編寫的代碼違反了 PEP 8 規(guī)范的時候,會給出警告信息和修正的建議。與此同時,還有專門的檢查工具對 Python 的代碼風(fēng)格進行檢查。

由上,還是建議在編寫 Python 代碼的時候都遵循 PEP 8 編碼規(guī)范,畢竟你以后不可能是只一個人寫代碼,未來不論是在公司或者某些開源項目中,作為其中的一份子,肯定還是要在風(fēng)格上向大眾看齊的。

PEP 8 編碼規(guī)范詳細的給出了 Python 編碼的指導(dǎo),包括什么對齊啦,包的導(dǎo)入順序啦,空格和注釋啦還有命名習(xí)慣等方方面面,并且還有詳細的事例。

下面我以「包」的導(dǎo)入為例,看一下 PEP 8 給出的具體編程指導(dǎo)。在 Python 中, import 應(yīng)該一次只導(dǎo)入一個模塊,不同的模塊應(yīng)該獨立一行:

importpandasimportnumpy

反面例子:

importpandas,numpy

如果想要從一個模塊里面導(dǎo)入多個,也可以像下面這樣:

fromsubprocessimportPopen,PIPE

import 語句應(yīng)該處于源碼文件的頂部,位于模塊注釋和文檔字符串之后,全局變量和常量之前。在導(dǎo)入不同的庫的時候,應(yīng)該按照以下的順序分組,各個分組之間以空行分隔:

導(dǎo)入標準庫模塊

導(dǎo)入相關(guān)第三方庫模塊

導(dǎo)入當前應(yīng)用程序/庫模塊

具體事例如下所示:

importosimporttimeimportpsutilfromtestimportu_test,my_test

Python 中還支持相對導(dǎo)入和絕對導(dǎo)入,在這里還是強推絕對導(dǎo)入。因為絕對導(dǎo)入的可讀性更好一些,也不容易出錯,即使出錯了也會給出更加詳細的錯誤信息。具體如下所示:

fromsub_packageimporttoolsfromsub_package.toolsimportmsg

當然除了上述以外還有更多對于包的規(guī)范的描述,PEP 8 的編碼風(fēng)格指導(dǎo)比較長,并且寫的非常詳細,所以我就不在這一一介紹了,詳細的可以參考 Python 官網(wǎng)上的資料

pycodestyle 檢查代碼規(guī)范

我在上面說過 PEP 8 只是官方給出的 Python 編碼規(guī)范,并沒有強制要求大家都遵守,但是又由于大家都在用,所以它也就變成了事實上的 Python 代碼風(fēng)格標準,既然都是標準了,那么就應(yīng)該有工具來檢查這個標準,這樣可以幫助 Python 小白規(guī)范自己的代碼,也可以幫助大家在開源或者工作中形成統(tǒng)一的代碼風(fēng)格。

為了達成上述的目的,官方提供了同名的命令行工具來檢查 Python 代碼是否違反了 PEP 8 規(guī)范,并且對違反規(guī)范的地方給出了相應(yīng)的提示信息。

pipinstallpep8

規(guī)范的名字是 PEP 8 ,這個檢查代碼風(fēng)格的命令行工具叫 pep8,這個很容易引起大家的困惑,因此 Python 之父建議將 pep8 重新命名為 pycodestyle,下面我們來看一下 pycodestyle 的用法。

首先通過 pip 安裝一下:

pipinstallpycodestyle

對一個或者多個文件運行 pycodestyle,打印檢查報告:

通過 --show-source 顯示不符合規(guī)范的源碼,以便程序員進行修改,具體如下所示:

autopep8 格式化代碼

autopep8 能夠?qū)?Python 代碼自動格式化為 PEP 8 風(fēng)格,它使用 pycodestyle 工具來決定代碼中的哪部分需要被格式化,這能夠修復(fù)大部分 pycodestyle 工具中報告的排版問題。autopep8 本身也是一個用 Python 寫的工具,所以我們還是可以用 pip 直接安裝:

pipinstallautopep8

它的使用方式也很簡單,具體如下所示:

autopep8--in-placetest_search.py

上述代碼如果不帶 --in-place 的話,會將 autopep8 格式化以后的代碼直接輸出到控制臺。我們可以用這種方式檢查 autopep8 的修改,使用 --in-place 則會直接將結(jié)果保存到源文件中。在這我繼續(xù)用上面的例子中用到的 py 文件,具體如下所示:

上面的例子中,autopep8 順利的修復(fù)了所有的問題,但是如果你這個時候查看源文件的話,你會發(fā)現(xiàn)源文件的內(nèi)容還是和原來一樣,并沒有被修改。這個時候我們就要用到 --in-place,加上這個選項將不會有任何輸出, autopep8 會直接修改源文件。

autopep8--in-placetest_search.py

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

    關(guān)注

    30

    文章

    4722

    瀏覽量

    68236
  • 編輯器
    +關(guān)注

    關(guān)注

    1

    文章

    800

    瀏覽量

    31055
  • python
    +關(guān)注

    關(guān)注

    55

    文章

    4767

    瀏覽量

    84376

原文標題:如何寫出符合Python審美的代碼風(fēng)格?

文章出處:【微信號:rgznai100,微信公眾號:rgznai100】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    Python全套教程_Python從入門到精通day1_10-PEP8 編碼規(guī)范

    python
    電子學(xué)習(xí)
    發(fā)布于 :2023年01月13日 15:55:11

    Python編碼規(guī)范分享

    國際規(guī)范名:PEP 8變量名規(guī)范(標識符規(guī)范)字符串函數(shù)名小寫, 多個單詞用 _ 分隔開由字母數(shù)字或下劃線組成,首字母不能為數(shù)字 2. 不能
    發(fā)表于 10-27 07:15

    介紹一種H.264編碼中幀間模式選擇的算法

    本文提出了一種H.264編碼中幀間模式選擇的算法,并針對該算法給出了4計算閾值的方法。
    發(fā)表于 06-04 07:17

    一種實用的混沌保密編碼方法

    基于實用符號動力學(xué)的基礎(chǔ)理論,提出了一種實用的混沌保密編碼方法,該方法借助于單峰的logistic映射處于混沌吸引子狀態(tài)時產(chǎn)生的符號序列作為密鑰,對信源編碼信號進行加密
    發(fā)表于 11-18 00:17 ?12次下載

    一種安全的糾錯網(wǎng)絡(luò)編碼

    該文利用消息空間的所有子空間上的一種度量,給出了一種安全的糾錯網(wǎng)絡(luò)編碼。首先,此度量下的最小距離譯碼法可以糾正定維數(shù)的錯誤。另外,在此
    發(fā)表于 11-09 13:32 ?19次下載

    一種實用的混沌保密編碼方法

    一種實用的混沌保密編碼方法 基于實用符號動力學(xué)的基礎(chǔ)理論,提出了一種實用的混沌保密編碼方法,該方法借助于單峰的logistic映射處于混沌
    發(fā)表于 11-18 10:55 ?10次下載

    一種數(shù)字調(diào)幅廣播編碼調(diào)制器技術(shù)

    本文通過對寬帶數(shù)據(jù)鏈及其關(guān)鍵技術(shù)的研究,提出了一種基于 DSP 的數(shù)字調(diào)幅廣播DRM(Digital Radio Mondiale)編碼調(diào)制器的實現(xiàn)方案,給出了
    發(fā)表于 12-28 11:23 ?20次下載

    一種頻率編碼鍵盤的設(shè)計與實現(xiàn)

    基于頻率編碼的思想,設(shè)計了一種頻率編碼鍵盤,分析了電路的工作機理,并給出了有關(guān)的匯編程序,從而達到僅用條I/O 線識別多個按鍵的目的,簡化
    發(fā)表于 06-23 16:49 ?0次下載
    <b class='flag-5'>一種</b>頻率<b class='flag-5'>編碼</b>鍵盤的設(shè)計與實現(xiàn)

    基于雙向MIMO中繼系統(tǒng)的一種預(yù)編碼策略

    為了克服已有的雙向MIMO中繼系統(tǒng)模型中預(yù)編碼技術(shù)計算量大的缺點,提出了一種基于雙向MIMO系統(tǒng)的三時段預(yù)編碼策略,給出了該策略的模型和算法
    發(fā)表于 06-09 16:39 ?34次下載
    基于雙向MIMO中繼系統(tǒng)的<b class='flag-5'>一種</b>預(yù)<b class='flag-5'>編碼</b>策略

    一種頻率編碼鍵盤的設(shè)計與實現(xiàn)

    基于頻率編碼的思想,設(shè)計了一種頻率編碼鍵盤,分析了電路的工作機理,并給出了有關(guān)的匯編程序,從而達到了僅用條I/O線識別多個按鍵的目的 ,簡
    發(fā)表于 03-30 17:02 ?10次下載

    初入門Python的小白介紹PEP是什么?

    或許你是個初入門Python的小白,完全不知道PEP是什么。又或許你是個學(xué)會了Python的熟手,見過幾個PEP,卻不知道這玩意背后是什么
    發(fā)表于 11-20 14:38 ?2247次閱讀
    初入門<b class='flag-5'>Python</b>的小白介紹<b class='flag-5'>PEP</b>是什么?

    Python一種什么語言,它可以用來做些什么

    智慧人生,首選Python Python一種什么語言? Python一種計算機程序設(shè)計語言。你可能已經(jīng)聽說過很多種流行的編程語言,比如非
    發(fā)表于 04-12 10:56 ?1271次閱讀

    處理器擴展包(PEP)和調(diào)試頭規(guī)范

    處理器擴展包(PEP)和調(diào)試頭規(guī)范免費下載。
    發(fā)表于 05-12 10:31 ?8次下載

    Python中的默認編碼

    我們使用Pycharm來編寫Python程序時會指定工程編碼和文件編碼為UTF-8,那么Python代碼被保存到磁盤時就會被轉(zhuǎn)換為UTF-
    的頭像 發(fā)表于 07-05 16:11 ?1088次閱讀
    <b class='flag-5'>Python</b>中的默認<b class='flag-5'>編碼</b>

    Python字符編碼轉(zhuǎn)換

    UNICODE字符串可以與任意字符編碼的字節(jié)進行相互轉(zhuǎn)換,如圖: 那么大家很容易想到個問題,就是不同的字符編碼的字節(jié)可以通過Unicode相互轉(zhuǎn)換嗎?答案是肯定的。 Python2中
    的頭像 發(fā)表于 07-05 16:25 ?1037次閱讀
    <b class='flag-5'>Python</b>字符<b class='flag-5'>編碼</b>轉(zhuǎn)換