作為一個編程人員,每天除了測試外,很大一部分的時間都在敲代碼中度過。那么有沒有人想過我們寫的代碼到底有多少行呢?逐條去查數(shù)目顯然是不現(xiàn)實的,不說浪費了大量的時間,而且我們?nèi)斯さ牟閿?shù)會出現(xiàn)失誤,一行行密密麻麻的代碼也看著頭暈眼花的。下面小編就教大家python3中代碼行數(shù)計算的方法。
首先判斷傳入?yún)?shù)是否為文件夾,不是則打印出提示,否則繼續(xù)(無返回),獲得目錄后,yongos.listdir對路徑下文件進行遍歷,其中也包含文件夾,再次判斷是否為文件夾,是的話則遞歸調(diào)用此函數(shù),否則開始執(zhí)行行數(shù)統(tǒng)計,這里用os.path.join將路徑與文件名進行拼接,方便之后直接傳給函數(shù),邏輯很簡單,無非是執(zhí)行文件判斷,判斷是哪類文件,在調(diào)用對應的注釋監(jiān)測正則代碼段進行抓取,抓取到則行數(shù)+1,空白行也是一樣的原理,用strip(去除前后空格),然后行內(nèi)內(nèi)容為空則為空行,代碼段即為總行數(shù)減去其他兩類行數(shù),最后在外層將所有文件對應的代碼段累加即為total。
關鍵
函數(shù)內(nèi)部是可以訪問全局變量的,問題在于函數(shù)內(nèi)部修改了變量,導致python認為它是一個局部變量。
所以,如果在函數(shù)內(nèi)部訪問并修改全局變量,應該使用關鍵字 global 來修飾變量。
import os
import re
#定義規(guī)則抓取文件中的python注釋
re_obj_py = re.compile('[(#)]')
#定義規(guī)則抓取文件中的C語言注釋
re_obj_c = re.compile('[(//)(/*)(*)(*/)]')
#判斷是否為python文件
def is_py_file(filename):
if os.path.splitext(filename)[1] == '.py':
return True
else:
return False
#判斷是否為c文件
def is_c_file(filename):
if os.path.splitext(filename)[1] in ['.c', '.cc', '.h']:
return True
else:
return False
#定義幾個全局變量用于計算所有文件總和(全部行數(shù)、代碼行數(shù)、空行數(shù)、注釋行數(shù))
all_lines, code_lines, space_lines, comments_lines = 0, 0, 0, 0
#判斷是否為文件夾,不是則輸出提示
def count_codelines(dirpath):
if not os.path.isdir(dirpath):
print('input dir: %s is not legal!' % dirpath)
return
# 定義幾個全局變量用于計算每個文件行數(shù)(全部行數(shù)、代碼行數(shù)、空行數(shù)、注釋行數(shù))
global all_lines, code_lines, space_lines, comments_lines
#列出當前文件夾下的文件(包含目錄)
all_files = os.listdir(dirpath)
for file in all_files:
#將文件(目錄)名與路徑拼接
file_name = os.path.join(dirpath, file)
if os.path.isdir(file_name):
count_codelines(file_name)
else:
temp_all_lines, temp_code_lines, temp_space_lines, temp_comments_lines = 0, 0, 0, 0
f = open(file_name)
for line in f:
temp_all_lines += 1
if line.strip() == '':
temp_space_lines += 1
continue
if is_py_file(file_name) and re_obj_py.match(line.strip()):
temp_comments_lines += 1
if is_c_file(file_name) and re_obj_c.match(line.strip()):
temp_comments_lines += 1
temp_code_lines = temp_all_lines - temp_space_lines - temp_comments_lines
print('%-15s : all_lines(%s)\t code_lines(%s)\t space_lines(%s)\t comments_lines(%s)'
% (file, temp_all_lines, temp_code_lines, temp_space_lines, temp_comments_lines))
all_lines += temp_all_lines
code_lines += temp_code_lines
space_lines += temp_space_lines
comments_lines += temp_comments_lines
if __name__ == '__main__':
count_codelines('test')
print('\n**** TOTAL COUNT ****\nall_lines = %s\ncode_lines = %s\nspace_lines = %s\ncomments_lines = %s' % (all_lines, code_lines, space_lines, comments_lines))
在使用以上超長的計算代碼之前,小伙伴們一定要理清計算行數(shù)的思路,再進行下一步的操作。畢竟如果計算的過程中出現(xiàn)問題,想要找出錯誤點是非常困難的。
如果你現(xiàn)在想學習python,贏取高薪工作機會,非常簡單,填寫下面信息,學好python技術高薪工作機會唾手可得。
上一篇:想知道python中的queue模塊如何使用?點進來就對了
下一篇: 沒有了
初級會計職稱中級會計職稱經(jīng)濟師注冊會計師證券從業(yè)銀行從業(yè)會計實操統(tǒng)計師審計師高級會計師基金從業(yè)資格稅務師資產(chǎn)評估師國際內(nèi)審師ACCA/CAT價格鑒證師統(tǒng)計資格從業(yè)
一級建造師二級建造師消防工程師造價工程師土建職稱房地產(chǎn)經(jīng)紀人公路檢測工程師建筑八大員注冊建筑師二級造價師監(jiān)理工程師咨詢工程師房地產(chǎn)估價師 城鄉(xiāng)規(guī)劃師結構工程師巖土工程師安全工程師設備監(jiān)理師環(huán)境影響評價土地登記代理公路造價師公路監(jiān)理師化工工程師暖通工程師給排水工程師計量工程師
執(zhí)業(yè)藥師執(zhí)業(yè)醫(yī)師衛(wèi)生資格考試衛(wèi)生高級職稱護士資格證初級護師主管護師住院醫(yī)師臨床執(zhí)業(yè)醫(yī)師臨床助理醫(yī)師中醫(yī)執(zhí)業(yè)醫(yī)師中醫(yī)助理醫(yī)師中西醫(yī)醫(yī)師中西醫(yī)助理口腔執(zhí)業(yè)醫(yī)師口腔助理醫(yī)師公共衛(wèi)生醫(yī)師公衛(wèi)助理醫(yī)師實踐技能內(nèi)科主治醫(yī)師外科主治醫(yī)師中醫(yī)內(nèi)科主治兒科主治醫(yī)師婦產(chǎn)科醫(yī)師西藥士/師中藥士/師臨床檢驗技師臨床醫(yī)學理論中醫(yī)理論