在 Python 中這樣命名變數就是給自己挖坑

来源:https://www.cnblogs.com/qingdeng123/archive/2019/08/09/11329525.html
-Advertisement-
Play Games

下麵這樣的一串代碼相信很多人都寫過,但可能除了你自己沒有人看得懂: for range in range(n): for j in range(m): for k in range(l): temp_value = X [i] [j] [k] * 12.5 new_array [i] [j] [k] ...


下麵這樣的一串代碼相信很多人都寫過,但可能除了你自己沒有人看得懂:

for range in range(n):
    for j in range(m):
        for k in range(l):
            temp_value = X [i] [j] [k] * 12.5 
            new_array [i] [j] [k] = temp_value + 150

 

為了圖方便,使用了簡單而無實際含義的變數以及數值,放在任何程式中都可以用,看的人要想半天或者上下查找才能知道變數是什麼意思,給別人修改和調試帶來很大麻煩。

所以如果你的代碼不僅僅是給自己看的,就儘量不要再這麼寫,多使用描述性變數名稱和命名常量編寫代碼,養成一個變數命名的好習慣。

來看看用標準變數怎麼寫上面的代碼:

PIXEL_NORMALIZATION_FACTOR = 12.5
PIXEL_OFFSET_FACTOR = 150

for row_index in range(row_count):
    for column_index in range(column_count):
        for color_channel_index in range(color_channel_count):
            normalized_pixel_value = (
                original_pixel_array[row_index][column_index][color_channel_index]
                * PIXEL_NORMALIZATION_FACTOR
            )
            transformed_pixel_array[row_index][column_index][color_channel_index] = (
                normalized_pixel_value + PIXEL_OFFSET_FACTOR
            )

 

雖然代碼量增大了,但是別人一看就能看懂,不管隔多久再來看很快就能明白,而第一段代碼,過一陣再看你還能明白是乾什麼的麽?

好的程式員都會遵守的代碼變數命名規則:

  • 變數名應該能夠描述變數表示的信息。
  • 優先考慮代碼的易懂性,而不是編寫代碼的速度。
  • 採用標準的命名約定,做出一個全局決策而不是多個本地決策。

所以命名不標準的原因主要有兩個:

  • 無益/混淆/模糊的變數名稱
  • 未命名的“魔法”常數

簡單來說,不要再像下麵這樣命名變數:

X, y, xs, x1, x2, tp, tn, clf, reg, xi, yi

要糾正也很簡單,遵守下麵三條簡單規則即可:

  • 變數/函數名稱:用小寫字母表示,中間用下劃線分割
  • 常量:用大寫字母
  • Class 類:首字母大寫,其餘小寫

詳細來說有這麼些註意事項:

  • ### Xy

X 和 y 你可能已經看過幾百次,知道它們的功能,但對於閱讀代碼的其他開發人員來說,這可能並不明顯。所以,不妨使用描述這些變數是代表什麼的名稱,例如:house_features 和 house_prices。

  • value

value 值具體是什麼呢?可能是一個velocity_mphcustomers_servedefficiencyrevenue_total。不同的 value 最後加一個詳細的首碼。

  • ### temp

臨時變數雖然可以用 temp 表示,但最好還是給它一個有意義的名稱。比如是需要轉換單位的值,像下麵這樣寫:

#不要這樣做
temp = get_house_price_in_usd(house_sqft,house_room_count)
final_value = temp * usd_to_aud_conversion_rate 

#這樣做(小編整理一套Python資料和PDF,有需要Python學習資料可以加學習群:631441315 ,反正閑著也是閑著呢,不如學點東西啦~~)
house_price_in_usd = get_house_price_in_usd(house_sqft,
                                            house_room_count)
house_price_in_aud = house_price_in_usd * usd_to_aud_conversion_rate

 

  • ### 縮寫:

如果使用縮寫變數,最好提前申明縮寫變數名的含義,比如usd, aud, mph, kwh, sqft這些。與普通縮寫的團隊其他成員達成一致並寫下來。然後,在代碼審查中,確保執行這些書面標準。

  • ### 避免機器學習特定的縮寫:

比如儘量不要用 tptnfpfn,這些縮寫變數,而是使用完整的變數代替:true_positives,true_negatives,false_positives,和false_negatives。

導致錯誤變數名直接原因?

下麵這兩個原因是寫出錯誤變數名的重要原因:

  • 希望保持變數名稱簡短
  • 將公式直接轉換為代碼

根據上面的公式,一般情況下很可能就直接寫成:

temp = m1 * x1 + m2 *(x2 ** 2)
final = temp + b

 

這是看起來像是機器編寫的代碼,雖然電腦最終將運行它,但人看的次數更多,最好編寫適合人理解的代碼:

house_price = price_per_room * rooms + price_per_floor_squared *(floor** 2)
house_price = house_price + expected_mean_house_price

 

不要使用魔法數字

魔法數字就是不是變數名的恆定值,通常用於單位轉換。但這樣的轉換代碼是錯誤的:

final_value = unreverted_value * 1.61 
final_quantity = quantity / 60 
value_with_offset = value + 150

 

沒人理解 1.61、60 表示什麼單位,自然也就看不懂轉換後的變數含義,所以最好給這個轉換數值賦予變數名,比如:

USD_TO_AUD_CONVERSION_RATE = 1.61 
price_in_aud = price_in_usd * USD_TO_AUD_CONVERSION_RATE

REVOLUTIONS_PER_MINUTE = 60 
revolution_count = minutes_elapsed * REVOLUTIONS_PER_MINUTE

 

以上就是在代碼變數命名過程中需要註意的一些細節。


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

-Advertisement-
Play Games
更多相關文章
  • 第十一章前端開發 11.1 HTTP 1.1引入了許多關鍵性能優化:keepalive連接,請求流水線,chunked編碼傳輸,位元組範圍請求等 1、keepalive連接: 2、Pipelining(請求流水線) 3、chunked編碼傳輸 4、位元組範圍請求 get 和 post 的區別: 1、參數 ...
  • 前段時間我們的服務遇到了性能瓶頸,由於前期需求太急沒有註意這方面的優化,到了要還技術債的時候就非常痛苦了。 在很低的 QPS 壓力下伺服器 load 就能達到 10-20,CPU 使用率 60% 以上,而且在每次流量峰值時介面都會大量報錯,雖然使用了服務熔斷框架 Hystrix,但熔斷後服務卻... ...
  • 如有不足,歡迎指正! ...
  • 一. 異常 1.1 概念 Java程式在運行時期發生的問題就是異常。 在Java中,把異常封裝成了一個類。 當發生了某些問題時,系統會自動創建對應的異常對象並拋出該異常相關的信息。 1.2 異常的體系 Throwable Error:用於指示合理的應用程式不應該試圖捕獲的嚴重問題 Exception ...
  • .lib .dll文件都是程式可直接引用的文件,前者就是所謂的庫文件,後者是動態鏈接庫(Dynamic Link Library)也是一個庫文件。而.pdb則可以理解為符號表文件。動態庫在沒有lib文件時,也可以通過顯示鏈接進行引用。 ...
  • 請求庫: 1. requests 這個庫是爬蟲最常用的一個庫 2. Selenium Selenium 是一個自動化測試工具,利用它我們可以驅動瀏覽器執行特定的動作,如點擊、下拉等操作 對於一些用JS做誼染的頁面來說,這種抓取方式是非常有效的。 3.ChomeDrive 安裝了這個庫,才能驅動Chr ...
  • ![](https://img2018.cnblogs.com/blog/1752914/201908/1752914-20190809210316241-1751719075.png) ...
  • Python3 匿名函數 定義一個函數與變數的定義非常相似,對於有名函數,必須通過變數名訪問 匿名函數定義:使用 lambda 來創建匿名函數 匿名函數1. 沒有名字 2:函數體自帶return 匿名函數 匿名函數的應用場景:應用於一次性的場景,臨時使用 2、匿名函數結合使用內置函數的用法 max, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...