Python統(tǒng)計(jì)python文件中代碼,注釋及空白對(duì)應(yīng)的行數(shù)示例【測(cè)試可用】
本文實(shí)例講述了Python實(shí)現(xiàn)統(tǒng)計(jì)python文件中代碼,注釋及空白對(duì)應(yīng)的行數(shù)。分享給大家供大家參考,具體如下:
其實(shí)代碼和空白行很好統(tǒng)計(jì),難點(diǎn)是注釋行
python中的注釋分為以#開(kāi)頭的單行注釋
或者以'''開(kāi)頭以'''結(jié)尾 或以"""開(kāi)頭以"""結(jié)尾的文檔注釋,如:
''' hello world '''
和
''' hello world'''
思路是用is_comment記錄是否存在多行注釋,如果不存在,則判斷當(dāng)前行是否以'''開(kāi)頭,是則將is_comment設(shè)為True,否則進(jìn)行空行、當(dāng)前行注釋以及代碼行的判斷,如果is_comment已經(jīng)為True即,多行注釋已經(jīng)開(kāi)始,則判斷當(dāng)前行是否以'''結(jié)尾,是則將is_comment設(shè)為False,同時(shí)增加注釋的行數(shù)。表示多行注釋已經(jīng)結(jié)束,反之繼續(xù),此時(shí)多行注釋還未結(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 #記錄以'''或"""開(kāi)頭的注釋位置
for index,line in enumerate(f,start=1):
line = line.strip() #去除開(kāi)頭和結(jié)尾的空白符
#判斷多行注釋是否已經(jīng)開(kāi)始
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)開(kāi)始
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)
運(yùn)行結(jié)果:
注釋:4
空行:2
代碼:26
注:這里的Python測(cè)試文件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("需要幾項(xiàng)?"))
n1=0
n2=1
count=2
if num<=0:
print("請(qǐng)輸入一個(gè)整數(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()
感興趣的朋友可以自己測(cè)試一下~
PS:這里再為大家推薦2款相關(guān)統(tǒng)計(jì)工具供大家參考:
在線字?jǐn)?shù)統(tǒng)計(jì)工具:
http://tools.jb51.net/code/zishutongji
在線字符統(tǒng)計(jì)與編輯工具:
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ìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
AMP?Tensor?Cores節(jié)省內(nèi)存PyTorch模型詳解
這篇文章主要為大家介紹了AMP?Tensor?Cores節(jié)省內(nèi)存PyTorch模型詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
Python lxml解析HTML并用xpath獲取元素的方法
今天小編就為大家分享一篇Python lxml解析HTML并用xpath獲取元素的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-01-01
使用Pandas解決對(duì)比兩列數(shù)據(jù)取最大值
Pandas庫(kù)作為Python中數(shù)據(jù)處理和分析的強(qiáng)大工具,提供了多種靈活的方法來(lái)實(shí)現(xiàn)這一需求,本文將詳細(xì)介紹五種使用Pandas對(duì)比兩列數(shù)據(jù)并取最大值的方法,需要的可以參考下2024-04-04
python查看自己安裝的所有庫(kù)并導(dǎo)出的命令
這篇文章主要介紹了python查看自己安裝的所有庫(kù)并導(dǎo)出,主要包括查看安裝的庫(kù)通過(guò)命令查詢,導(dǎo)出庫(kù)安裝文件執(zhí)行命令,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
Python使用Turtle圖形函數(shù)畫圖顏色填充實(shí)例
這篇文章主要介紹了Python使用Turtle圖形函數(shù)畫圖顏色填充實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
一文搞懂Python中Pandas數(shù)據(jù)合并
pandas是基于NumPy的一種工具,該工具是為了解決數(shù)據(jù)分析任務(wù)而創(chuàng)建的。Pandas納入了大量庫(kù)和一些標(biāo)準(zhǔn)的數(shù)據(jù)模型,提供了高效操作大型數(shù)據(jù)集的工具。pandas提供大量快速便捷地處理數(shù)據(jù)的函數(shù)和方法。你很快就會(huì)發(fā)現(xiàn),它是使Python強(qiáng)大而高效的數(shù)據(jù)分析環(huán)境的重要因素之一2021-11-11
Python私有屬性私有方法應(yīng)用實(shí)例解析
這篇文章主要介紹了Python私有屬性私有方法應(yīng)用場(chǎng)景解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
通過(guò)cmd進(jìn)入python的實(shí)例操作
在本篇內(nèi)容中小編給大家分享了關(guān)于通過(guò)cmd怎么進(jìn)入python的實(shí)例操作方法和步驟,有需要的朋友們可以參考下。2019-06-06

