python編程規範系列--建議01~07

来源:https://www.cnblogs.com/zhangbc/archive/2019/01/18/10285549.html
-Advertisement-
Play Games

本系列來自《編寫高質量代碼 改善python程式的91個建議》的讀書筆記整理。 ...


  本系列來自《編寫高質量代碼 改善python程式的91個建議》的讀書筆記整理。

本書主要內容

    1)容易被忽視的重要概念和常識,如代碼的佈局和編寫函數的原則等;     2)編寫python程式管用的方法,如利用assert語句去發現問題,使用enumerate()獲取序列迭代的索引和值等;     3)語法中的關鍵條款,如有節制地使用from…import語句,異常處理的幾點基本原則等;     4)常見庫的使用,如按需選擇sort()或者sorted(),使用Queue使多線程更安全等;     5)python設計模式的使用,如用發佈訂閱模式實現松耦合,用狀態模式美化代碼等;     6)python內部機制,如名字查找機制,描述符機制等;     7)開發工具的使用,如pip等各種開發工具的使用,各種代碼測試用具的使用等;     8)python代碼的性能分析,優化的原則,工具,技巧,以及常見性能問題的解決等。

本章主要內容

        建議1:理解pythonic概念         建議2:編寫pythonic代碼         建議3:理解python與C語言的不同之處         建議4:在代碼中適當添加註釋         建議5:通過適當添加空行使代碼佈局更為優雅,合理         建議6:編寫函數的4個原則         建議7:將常量集中到一個文件

建議1:理解pythonic概念

    1)pythonic:充分體現python自身特色的代碼風格。     2)舉例:
1 # 交換兩個變數的值,packaging/unpackaging機制
2 x = 2
3 y = 3
4 x, y = y, x
5 print x, y
1 # 字元串格式化
2 print 'Hello %(name)s!' % {'name': 'Tom'}
1 # 字元串格式化
2 print 'Hello {name}!'.format(name='Tom')
    3)python的包和模塊結構: (1) 包和模塊的命名採用小寫,單數形式且短小;(2)包通常作為命名空間,如只包含空的__init__.py文件。

建議2:編寫pythonic代碼

    1)要避免劣化代碼:(1)避免只用大小寫來區分不同的對象;(2)避免使用容易引起混淆的名稱;(3)不要害怕過長的變數名;     2)pep8檢測工具:
1 C:\>pip install -U pep8
2 
3 C:\Users\Administrator\Desktop\zxt>pep8 --first database.py
4 database.py:83:1: E302 expected 2 blank lines, found 1
5 
6 >pep8 --show-source --show-pep8 waijiao.py

建議3:理解python與C語言的不同之處

    1)縮進{}     2)'"     3)三元操作符?:     4)switch...case
1 n = raw_input("please input a number:")
2 if n == "0":
3 print "You typed zero."
4 elif n == "1":
5 print "You are in top."
6 elif n == "2":
7 print "N is an even number."
8 else:
9 print "Error!"
用跳轉可以實現:
1 def func():
2      return {
3          "0": "You typed zero.",
4          "1": "You are in top.",
5          "2": "N is an even number."
6      }.get(n, "Error!")

建議4:在代碼中適當添加註釋

    1)使用塊或者行註釋的時候僅註釋複雜的操作,演算法,難以理解的技巧或者不夠一目瞭然的代碼;     2)註釋和代碼隔開一定的距離;     3)給外部可訪問的函數和方法添加文檔註釋(ddocstring)(""" """);     4)推薦文件頭部包含copyright申明。模塊描述等。
 1 """
 2 Requests HTTP library
 3 ~~~~~~~~~~~~~~~~~~~~~
 4 Requests is an HTTP library, written in Python, for human beings. Basic GET
 5 usage:
 6    >>> import requests
 7    >>> r = requests.get('https://www.python.org')
 8    >>> r.status_code
 9    200
10    >>> 'Python is a programming language' in r.content
11    True
12 ... or POST:
13    >>> payload = dict(key1='value1', key2='value2')
14    >>> r = requests.post('http://httpbin.org/post', data=payload)
15    >>> print(r.text)
16    {
17      ...
18      "form": {
19        "key2": "value2",
20        "key1": "value1"
21      },
22      ...
23    }
24 The other HTTP methods are supported - see `requests.api`. Full documentation
25 is at <http://python-requests.org>.
26 :copyright: (c) 2015 by Kenneth Reitz.
27 :license: Apache 2.0, see LICENSE for more details.
28 """

建議5:通過適當添加空行使代碼佈局更為優雅,合理

    1)在一組代碼表達完一個完整的思路之後,應該用空白進行間隔;     2)儘量保持上下文語義的易理解性(如調用函數寫在被調用函數之上);     3)避免過長的代碼行,每行最好不要超過80個字元;     4)不要為了保持水平對齊而使用多餘的空格;     5)空格是使用要能在需要強調的時候警示讀者:         (1)二元運算符的左右兩邊應該有空格;         (2)逗號和分號前不要使用空格;         (3)函數名和左右括弧之間,序列索引操作時序列名和[ ]之間不要空格,函數預設參數兩側不需要空格;         (4)強調前面的操作符的時候使用空格。

建議6:編寫函數的4個原則

    1)函數設計儘量短小,嵌套層次不宜過深(最好控制在3層以內);     2)函數聲明應該做到合理,簡單,易於使用;     3)函數參數設計應該考慮向下相容;     4)一個函數只做一件事,儘量保證函數語句粒度的一致性。

建議7:將常量集中到一個文件

示例:const.py
 1 # -*-coding:UTF-8 -*-
 2 
 3 import sys
 4 
 5 
 6 class _const(object):
 7 
 8     class ConstError(TypeError):
 9         pass
10 
11     class ConstCaseError(ConstError):
12         pass
13 
14     def __setattr__(self, name, value):
15         if self.__dict__.has_key(name):
16             raise self.ConstError, "Can't change const.{name}".format(name=name)
17         if not name.isupper():
18             raise self.ConstCaseError, 'const name "{name}" is not all uppercase'.format(name=name)
19         self.__dict__[name] = value
20 
21 
22 sys.modules[__name__] = _const()

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 先看看表單如何工作吧 請求 響應 簡要工作流程: 瀏覽器載入頁面 用戶輸入數據 用戶提交表單 伺服器響應 概念都清楚了,我們來寫表單吧 只有一個html文件 這是顯示 你可以向空白框框里寫一些東西,然後點擊提交 數據會發到web伺服器的contest.php里,當然了,你也可以自己寫一個php文件 ...
  • let命令的用法 是es6中的聲明一個變數的命令,只在它聲明的代碼塊中有效,出了這個代碼塊就會報錯。也非常適合 迴圈,在迴圈中i的值只在迴圈語句中生效,在外邊取不到的。 命令聲明的是一個全局的變數,i是指向全局的變數,只會輸出最後的值。而 只在迴圈語句塊裡面生效,每次迴圈都會重新聲明一個i的,所以每 ...
  • 如果這是第二次看到我的文章,歡迎右側掃碼訂閱我喲~ 👉 本文長度為2728字,建議閱讀8分鐘。 堅持原創,每一篇都是用心之作~ 前面聊完的2個章節「數據一致性」和「高可用」其實本質是一個通過提升複雜度讓整體更完善的方式。 接下去我們開始聊一些讓系統更簡單,更容易維護的東西——「易伸縮」,首當其衝的 ...
  •   需求變更是信息化過程中的家常便飯,而在變更過程中如何儘可能小的影響線上業務是比較頭疼的事情。舉個車聯網監控的例子:原終端設備上傳車輛的經緯度數據,新的終端設備支持同時上傳速度數據,而舊的車輛狀態表數據量超過億級,此時如果Alter table add column將會造成數據 ...
  • 一、問題描述 Tomcat下麵部署很多個java項目的war包,tomcat啟動一段時間後,發現cpu占用過高,整個界面卡死! 二、通過process explorer查看java進程下的線程 process explorer是Windows系統和應用程式監視工具。 process explorer ...
  • 字元串,是Java中最重要的類。這句肯定的推斷不是Java之父詹姆斯·高斯林說的,而是沉默王二說的,因此你不必懷疑它的準確性。 關於字元串,有很多的面試題,但我總覺得理論知識繞來繞去沒多大意思。你比如說:String cmower = new String("沉默王二");定義了幾個對象? 我總覺得 ...
  • 首先嘗試網友們的方法 按照網上大部分的教程仍無法解決自己的問題,不管是更改.project文件還是使用其他修改配置的方法,始終不能解決問題。 嘗試自己解決問題 想到了可能是eclipse版本的問題,我之前使用的是eclipse mars版本。我隨即去官網下載了最新版本的eclipse。下載後導入項目 ...
  • 背景:併發知識是一個程式員段位升級的體現,同樣也是進入BAT的必經之路,有必要把併發知識重新梳理一遍。 說到併發concurrent,肯定首先想到了線程,創建線程有兩種方法:1、從Java.lang.Thread類派生一個新的線程類,重載它的run()方法;2、實現Runnalbe介面,重載Runn ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...