国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python實現統計代碼行的方法分析

2020-02-16 01:50:04
字體:
來源:轉載
供稿:網友

本文實例講述了Python實現統計代碼行的方法。分享給大家供大家參考,具體如下:

參加光榮之路測試開發班已三月有余,吳總上課也總問“ 咱們的課上了這么多次了大家實踐了多少行代碼了?”。這里是一個一臉懵逼的表情。該怎么統計呢?一個個文件數當然不可取,能用代碼解決的事咱們堅決不動手。最近在網上刷題時也正好遇到有這么一道題,所以決定擼一擼。

題目:有個目錄,里面是你自己寫過的程序,統計一下你寫過多少行代碼。包括空行和注釋,但是要分別列出來。

首先分析一下思路捋一下大象裝冰箱的步驟,從一個給定的目錄統計該目錄下所有的代碼行大致需要以下7個步驟:

1. 遍歷該目錄下所有的文件。
2. 判斷文件是否以“.py”結尾。(以python代碼為例)
3. 打開.py文件(切忌勿用W+,W+會清空文件內容)
4. 循環讀取文件的每一行
5. 判斷每一行的內容:
                  (a) 注釋: 以#開頭。
                  (b) 注釋:以三引號開頭結束。
                  (c) 空行:除空白字符無其他。
                  (d) 代碼行:除空白字符之后還剩下其他字符。
6. 判斷是否為文件末尾,
7. 關閉文件, 返回結果.

解題思路捋清楚之后剩下的就是將各模塊的代碼像搭積木一樣搭起來就完事了(示例代碼在本文最后):

5~9: 導入OS,定義 code_lines_count 函數并接收一個 path 形式參數,聲明了三個變量分別用于統計代碼行,注釋行和空行
10~13: 遍歷os.walk獲取到的file 對象,然后將文件的后綴名利用splitext函數分割然后使用列表索引 [1] 取得文件后綴名,并判斷是否是以“.py”結尾。(此處也可以使用listdir, 但listdir只能取單層目錄下的文件, 并且需要單獨判斷取得的元素是文件還是文件夾,較麻煩)
第12行定義了一個file_abs_path的變量并賦值文件的絕對路徑,是因為下面的代碼會多次使用,不必每次都使用so.path.join(xx,xx)。
14~18:對于上一個步驟獲取到的以“.py”結尾的文件 利用with 方式打開(使用with可省去關閉文件的代碼),對于打開的文件使用While True 循環的使用readline()去讀取文件的每一行并賦值給line 變量。
19~39:該段代碼用于對上一步驟readline()取得的行做判斷是 代碼行,空行還是注釋行。
19~21:如果line為空,表示取到文件末尾,此時break while 循環,繼續files 中的下一個文件操作。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 霍州市| 乐亭县| 资溪县| 蒙阴县| 郎溪县| 英山县| 丹凤县| 乌兰浩特市| 桐乡市| 裕民县| 新野县| 富平县| 分宜县| 通辽市| 白水县| 新巴尔虎左旗| 大姚县| 诸暨市| 安福县| 兴文县| 辽中县| 于都县| 永泰县| 抚宁县| 波密县| 贡嘎县| 信丰县| 洛浦县| 波密县| 镶黄旗| 宜昌市| 兰坪| 噶尔县| 潞西市| 大荔县| 新化县| 洮南市| 体育| 辉县市| 上林县| 肥东县|