Python統(tǒng)計python文件中代碼,注釋及空白對應(yīng)的行數(shù)示例【測試可用】
本文實例講述了Python實現(xiàn)統(tǒng)計python文件中代碼,注釋及空白對應(yīng)的行數(shù)。分享給大家供大家參考,具體如下:
其實代碼和空白行很好統(tǒng)計,難點是注釋行
python中的注釋分為以#開頭的單行注釋
或者以'''開頭以'''結(jié)尾 或以"""開頭以"""結(jié)尾的文檔注釋,如:
''' hello world '''
和
''' hello world'''
思路是用is_comment記錄是否存在多行注釋,如果不存在,則判斷當(dāng)前行是否以'''開頭,是則將is_comment設(shè)為True,否則進行空行、當(dāng)前行注釋以及代碼行的判斷,如果is_comment已經(jīng)為True即,多行注釋已經(jīng)開始,則判斷當(dāng)前行是否以'''結(jié)尾,是則將is_comment設(shè)為False,同時增加注釋的行數(shù)。表示多行注釋已經(jīng)結(jié)束,反之繼續(xù),此時多行注釋還未結(jié)束
# -*- coding:utf-8 -*-
#!python3
path = 'test.py'
with open(path,'r',encoding='utf-8') as f:
code_lines = 0 #代碼行數(shù)
comment_lines = 0 #注釋行數(shù)
blank_lines = 0 #空白行數(shù) 內(nèi)容為'\n',strip()后為''
is_comment = False
start_comment_index = 0 #記錄以'''或"""開頭的注釋位置
for index,line in enumerate(f,start=1):
line = line.strip() #去除開頭和結(jié)尾的空白符
#判斷多行注釋是否已經(jīng)開始
if not is_comment:
if line.startswith("'''") or line.startswith('"""'):
is_comment = True
start_comment_index = index
#單行注釋
elif line.startswith('#'):
comment_lines += 1
#空白行
elif line == '':
blank_lines += 1
#代碼行
else:
code_lines += 1
#多行注釋已經(jīng)開始
else:
if line.endswith("'''") or line.endswith('"""'):
is_comment = False
comment_lines += index - start_comment_index + 1
else:
pass
print("注釋:%d" % comment_lines)
print("空行:%d" % blank_lines)
print("代碼:%d" % code_lines)
運行結(jié)果:
注釋:4
空行:2
代碼:26
注:這里的Python測試文件test.py如下:
# -*- coding:utf-8 -*-
#!python3
#九九乘法表
for i in range(1, 10):
for j in range(1, i+1):
print("%d*%d=%d\t" % (j, i, i*j), end="")
print()
#斐波那契數(shù)列 0,1,1,2,3,5,8,...
num=int(input("需要幾項?"))
n1=0
n2=1
count=2
if num<=0:
print("請輸入一個整數(shù)。")
elif num==1:
print("斐波那契數(shù)列:")
print(n1)
elif num==2:
print("斐波那契數(shù)列:")
print(n1,",",n2)
else:
print("斐波那契數(shù)列:")
print(n1,",",n2,end=" , ")
while count<num:
sum=n1+n2
print(sum,end=" , ")
n1=n2
n2=sum
count+=1
print()
感興趣的朋友可以自己測試一下~
PS:這里再為大家推薦2款相關(guān)統(tǒng)計工具供大家參考:
在線字數(shù)統(tǒng)計工具:
http://tools.jb51.net/code/zishutongji
在線字符統(tǒng)計與編輯工具:
http://tools.jb51.net/code/char_tongji
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python文件與目錄操作技巧匯總》、《Python文本文件操作技巧匯總》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
AMP?Tensor?Cores節(jié)省內(nèi)存PyTorch模型詳解
這篇文章主要為大家介紹了AMP?Tensor?Cores節(jié)省內(nèi)存PyTorch模型詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10
Python lxml解析HTML并用xpath獲取元素的方法
今天小編就為大家分享一篇Python lxml解析HTML并用xpath獲取元素的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-01-01
Python使用Turtle圖形函數(shù)畫圖顏色填充實例
這篇文章主要介紹了Python使用Turtle圖形函數(shù)畫圖顏色填充實例,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
一文搞懂Python中Pandas數(shù)據(jù)合并
pandas是基于NumPy的一種工具,該工具是為了解決數(shù)據(jù)分析任務(wù)而創(chuàng)建的。Pandas納入了大量庫和一些標(biāo)準的數(shù)據(jù)模型,提供了高效操作大型數(shù)據(jù)集的工具。pandas提供大量快速便捷地處理數(shù)據(jù)的函數(shù)和方法。你很快就會發(fā)現(xiàn),它是使Python強大而高效的數(shù)據(jù)分析環(huán)境的重要因素之一2021-11-11

