使用Black自由格式化Python
在我們覆蓋 7 個 PyPI 庫的系列文章中了解解決 Python 問題的更多信息。
Python 是當今使用最多的流行編程語言之一,因為:它是開源的,它有廣泛的用途(例如 Web 編程、業(yè)務應用、游戲、科學編程等等),它有一個充滿活力和專注的社區(qū)支持它。這個社區(qū)可以讓我們在 Python Package Index(PyPI)中有如此龐大、多樣化的軟件包,用以擴展和改進 Python 并解決不可避免的問題。
在本系列中,我們將介紹七個可以幫助你解決常見 Python 問題的 PyPI 庫。在***篇文章中,我們了解了 Cython。今天,我們將使用 Black 這個代碼格式化工具。
Black
有時創(chuàng)意可能是一件美妙的事情。有時它只是一種痛苦。我喜歡創(chuàng)造性地解決難題,但我希望我的 Python 格式盡可能一致。沒有人對使用“有趣”縮進的代碼印象深刻。
但是比不一致的格式更糟糕的是除了檢查格式之外什么都沒有做的代碼審查。這對審查者來說很煩人,對于被審查者來說甚至更煩人。當你的 linter 告訴你代碼縮進不正確時,但沒有提示正確的縮進量,這也會令人氣憤。
使用 Black,它不會告訴你要做什么,它是一個優(yōu)良、勤奮的機器人:它將為你修復代碼。
要了解它如何工作的,請隨意寫一些非常不一致的內(nèi)容,例如:
def add(a, b): return a+b
def mult(a, b):
return \
a * b
Black 抱怨了么?并沒有,它為你修復了!
$ black math
reformatted math
All done! ✨ 🍰 ✨
1 file reformatted.
$ cat math
def add(a, b):
return a + b
def mult(a, b):
return a * b
Black 確實提供了報錯而不是修復的選項,甚至還有輸出 diff 編輯樣式的選項。這些選項在持續(xù)集成 (CI)系統(tǒng)中非常有用,可以在本地強制運行 Black。此外,如果 diff 輸出被記錄到 CI 輸出中,你可以直接將其粘貼到 patch
中,以便在極少數(shù)情況下你需要修復輸出,但無法本地安裝 Black 使用。
$ black --check --diff bad
--- math 2019-04-09 17:24:22.747815 +0000
+++ math 2019-04-09 17:26:04.269451 +0000
@@ -1,7 +1,7 @@
-def add(a, b): return a + b
+def add(a, b):
+ return a + b
def mult(a, b):
- return \
- a * b
+ return a * b
would reformat math
All done! 💥 💔 💥
1 file would be reformatted.
$ echo $?
1
在本系列的下一篇文章中,我們將介紹 attrs ,這是一個可以幫助你快速編寫簡潔、正確的代碼的庫。