Python實現(xiàn)統(tǒng)計代碼行的方法分析
本文實例講述了Python實現(xiàn)統(tǒng)計代碼行的方法。分享給大家供大家參考,具體如下:
參加光榮之路測試開發(fā)班已三月有余,吳總上課也總問“ 咱們的課上了這么多次了大家實踐了多少行代碼了?”。這里是一個一臉懵逼的表情。該怎么統(tǒng)計呢?一個個文件數(shù)當然不可取,能用代碼解決的事咱們堅決不動手。最近在網(wǎng)上刷題時也正好遇到有這么一道題,所以決定擼一擼。
題目:有個目錄,里面是你自己寫過的程序,統(tǒng)計一下你寫過多少行代碼。包括空行和注釋,但是要分別列出來。
首先分析一下思路捋一下大象裝冰箱的步驟,從一個給定的目錄統(tǒng)計該目錄下所有的代碼行大致需要以下7個步驟:
1. 遍歷該目錄下所有的文件。
2. 判斷文件是否以“.py”結(jié)尾。(以python代碼為例)
3. 打開.py文件(切忌勿用W+,W+會清空文件內(nèi)容)
4. 循環(huán)讀取文件的每一行
5. 判斷每一行的內(nèi)容:
(a) 注釋: 以#開頭。
(b) 注釋:以三引號開頭結(jié)束。
(c) 空行:除空白字符無其他。
(d) 代碼行:除空白字符之后還剩下其他字符。
6. 判斷是否為文件末尾,
7. 關閉文件, 返回結(jié)果.
解題思路捋清楚之后剩下的就是將各模塊的代碼像搭積木一樣搭起來就完事了(示例代碼在本文最后):
5~9: 導入OS,定義 code_lines_count 函數(shù)并接收一個 path 形式參數(shù),聲明了三個變量分別用于統(tǒng)計代碼行,注釋行和空行
10~13: 遍歷os.walk獲取到的file 對象,然后將文件的后綴名利用splitext函數(shù)分割然后使用列表索引 [1] 取得文件后綴名,并判斷是否是以“.py”結(jié)尾。(此處也可以使用listdir, 但listdir只能取單層目錄下的文件, 并且需要單獨判斷取得的元素是文件還是文件夾,較麻煩)
第12行定義了一個file_abs_path的變量并賦值文件的絕對路徑,是因為下面的代碼會多次使用,不必每次都使用so.path.join(xx,xx)。
14~18:對于上一個步驟獲取到的以“.py”結(jié)尾的文件 利用with 方式打開(使用with可省去關閉文件的代碼),對于打開的文件使用While True 循環(huán)的使用readline()去讀取文件的每一行并賦值給line 變量。
19~39:該段代碼用于對上一步驟readline()取得的行做判斷是 代碼行,空行還是注釋行。
19~21:如果line為空,表示取到文件末尾,此時break while 循環(huán),繼續(xù)files 中的下一個文件操作。
22~24:使用strip()對readline()取得的行做去空白處理,如果經(jīng)過處理后是以“#”開頭則表示這行是一個注釋行 此時對comm_lines 做加1 操作。
25~33:使用strip()對readline()取得的行做去空白處理,如果經(jīng)過處理后是以三個單引號或者三個雙引號開頭則表示此處為一個多行注釋的開始,然后判斷該行的三引號數(shù)量如果為1則表示注釋分多行, 否則注釋為一行(一對三引號在同一行),對于注釋為多行情況使用while 循環(huán)得讀取接下來的行,并且沒讀一行對 comm_lines 做加1 操作,如果讀到某一行存在三引號則判定注釋結(jié)束,break 當層while循環(huán)(此處只考慮了比較規(guī)范的注釋)
34~36:如果讀到的行做過strip()之后非空且不是注釋,則是一個代碼行, 并對code_lines做加1操作。
37~39:如果上述條件都不滿足,則判斷為一個空行,并對space_lines 做加1操作。
41:返回統(tǒng)計到的代碼行,注釋行和空行。
43:測試代碼下圖是運行的一個實例

#_*_coding:utf-8_*_
# 統(tǒng)計代碼行數(shù), 空行, 注釋.
import os
def code_lines_count(path):
code_lines = 0
comm_lines = 0
space_lines = 0
for root,dirs,files in os.walk(path):
for item in files:
file_abs_path = os.path.join(root,item)
postfix = os.path.splitext(file_abs_path)[1]
if postfix == '.py':
#print 'Start: ',file_abs_path
with open(file_abs_path) as fp:
while True:
line = fp.readline()
if not line:
#print 'break here,%r' %line
break
elif line.strip().startswith('#'):
#print '1, here',line
comm_lines += 1
elif line.strip().startswith("'''") or line.strip().startswith('"""'):
comm_lines += 1
if line.count('"""') ==1 or line.count("'''") ==1:
while True:
line = fp.readline()
#print '4, here',line
comm_lines += 1
if ("'''" in line) or ('"""' in line):
break
elif line.strip():
#print '5, here',line
code_lines += 1
else:
#print '6, here',line
space_lines +=1
#print 'Done',file_abs_path
return code_lines,comm_lines,space_lines
#test
print "Code lines: %d\nComments lines: %d\nWhiteSpace lines: %d" %code_lines_count(r'D:\exercises')
--碼代碼本質(zhì)和打游戲一樣, 都是打怪升級穿裝備。
更多關于Python相關內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。
相關文章
Python?Asyncio中Coroutines,Tasks,Future可等待對象的關系及作用
這篇文章主要介紹了Python?Asyncio中Coroutines,Tasks,Future可等待對象的關系及作用,文章圍繞主題展開詳細的內(nèi)容介紹,需要的小伙伴可以參考一下2022-06-06
Python卷積神經(jīng)網(wǎng)絡圖片分類框架詳解分析
在機器視覺領域中,卷積神經(jīng)網(wǎng)絡算法作為一種新興算法出現(xiàn),在圖像識別領域中,卷積神經(jīng)網(wǎng)絡能夠較好的實現(xiàn)圖像的分類效果,而且其位移和形變具有較高的容忍能力2021-11-11
利用Python pandas對Excel進行合并的方法示例
這篇文章主要給大家介紹了關于利用Python pandas對Excel進行合并的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11

