人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

提高python代碼可讀性利器pycodestyle使用詳解

發(fā)布日期:2021-12-12 08:37 | 文章來源:源碼之家

編程是數(shù)據(jù)科學(xué)中不可或缺的技能,雖然創(chuàng)建腳本來執(zhí)行基本功能很容易,但編寫大規(guī)模可讀性良好的代碼需要更多的思考。

關(guān)于PEP-8

pycodestyle 檢查器提供基于 PEP-8 樣式約定的代碼建議。那么 PEP-8 到底是什么呢?

PEP 代表 Python 增強(qiáng)建議,PEP-8 是一個(gè)概述編寫 Python 代碼最佳實(shí)踐的指南。它的主要目標(biāo)是通過標(biāo)準(zhǔn)化代碼樣式來提高代碼的整體一致性和可讀性。

目的

快速瀏覽一下PEP-8文檔,就會(huì)發(fā)現(xiàn)有太多的最佳實(shí)踐需要記住。

而且,已經(jīng)花了這么多精力編寫了這么多行代碼,你當(dāng)然不希望浪費(fèi)更多的時(shí)間手動(dòng)檢查腳本的可讀性。

這就是 pycodestyle 自動(dòng)分析 Python 腳本并指出代碼可以改進(jìn)的地方。

安裝

pip 是首選的安裝程序,你可以通過在終端中運(yùn)行以下命令來安裝或升級(jí) pycodestyle:

# Install pycodestyle
pip install pycodestyle
# Upgrade pycodestyle
pip install --upgrade pycodestyle

基本用法

最直接的用法是在 Python 腳本(.py文件)上作為命令在終端中運(yùn)行pycodestyle。

讓我們使用以下示例腳本(名為 pycodestyle_sample_script.py)進(jìn)行演示:

# pycodestyle_sample_script.py 
# Import libraries
import numpy as np, pandas as pd
# Take the users input
words = raw_input("Enter some text to translate to pig latin: " )
# Break apart the words into a list
words_list = words.split(' ' )
for word in words_list:
 if len(word) >= 3 : # For this pig latin translation, we only want to translate words greater than 3 characters
  pig_latin = word + "%say" % (word[0])
  pig_latin = pig_latin[ 1: ]
  print(pig_latin )
 else:
  pass

我們通過運(yùn)行以下簡單命令來實(shí)現(xiàn)pycodestyle:

pycodestyle pycodestyle_sample_script.py

輸出指定違反PEP-8樣式約定的代碼位置:

每行中由冒號(hào)分隔的一對(duì)數(shù)字(如3:19)分別表示行號(hào)和字符號(hào)。

例如,在")"之前輸出6:64 E202空格意味著在第6行中,第64個(gè)字符標(biāo)記處有一個(gè)意外的空格。

你也可以通過分析 statistics 參數(shù)來查看錯(cuò)誤發(fā)生的頻率:

pycodestyle --statistics -qq pycodestyle_sample_script.py

在上面的輸出中,我們看到在右括號(hào)“)”之前出現(xiàn)了4次意外的空白。

高級(jí)用法

我們還可以將 pycodestyle 直接導(dǎo)入到 Python 代碼中,以執(zhí)行自動(dòng)化測(cè)試。這對(duì)于自動(dòng)測(cè)試多個(gè)腳本的編碼風(fēng)格一致性非常有用。

例如,可以編寫以下類來自動(dòng)檢查是否符合PEP-8約定:

import unittest
import pycodestyle
class TestCodeFormat(unittest.TestCase):
 def test_conformance(self):
  """Test that the scripts conform to PEP-8."""
  style = pycodestyle.StyleGuide(quiet=True)
  result = style.check_files(['file1.py', 'file2.py'])
  self.assertEqual(result.total_errors, 0, "Found style  
  errors")

還可以配置該工具,以便根據(jù)我們定義的樣式規(guī)則首選項(xiàng)進(jìn)行測(cè)試。例如,我們可以刪除不希望在檢查中檢測(cè)到的特定錯(cuò)誤:

style = pycodestyle.StyleGuide(ignore=['E201', 'E202', 'E501'])

或者,我們可以指示 pycodestyle 一起使用不同的配置文件(包含一組特定的樣式規(guī)則)。

import pycodestyle
style = pycodestyle.StyleGuide(config_file='/path/to/tox.ini')

如果你需要了解更多的功能,訪問pycodestyle文檔獲取更多詳細(xì)信息。

https://pycodestyle.pycqa.org/en/latest/intro.html

結(jié)論

代碼的閱讀頻率高于編寫頻率,代碼的一致性、可理解性和結(jié)構(gòu)整潔是至關(guān)重要的。在本文中,我們研究了如何使用 pycodestyle 工具來檢查 Python 腳本是否符合 PEP-8 代碼樣式規(guī)范。

相信掌握它后,我們代碼質(zhì)量會(huì)有質(zhì)的飛躍。

以上就是提高python代碼可讀性利器pycodestyle使用詳解的詳細(xì)內(nèi)容,更多關(guān)于python代碼可讀性利器pycodestyle的資料請(qǐng)關(guān)注本站其它相關(guān)文章!

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開通

自選配置、實(shí)時(shí)開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對(duì)1客戶咨詢顧問

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部