真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯網站制作重慶分公司

python中怎么統(tǒng)計代碼行數

這篇文章將為大家詳細講解有關python中怎么統(tǒng)計代碼行數,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

十年的惠安網站建設經驗,針對設計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。成都全網營銷推廣的優(yōu)勢是能夠根據用戶設備顯示端的尺寸不同,自動調整惠安建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現優(yōu)雅布局與設計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯從事“惠安網站設計”,“惠安網站推廣”以來,每個客戶項目都認真落實執(zhí)行。

流程

首先判斷傳入參數是否為文件夾,不是則打印出提示,否則繼續(xù)(無返回),獲得目錄后,yongos.listdir對路徑下文件進行遍歷,其中也包含文件夾,再次判斷是否為文件夾,是的話則遞歸調用此函數,否則開始執(zhí)行行數統(tǒng)計,這里用os.path.join將路徑與文件名進行拼接,方便之后直接傳給函數,邏輯很簡單,無非是執(zhí)行文件判斷,判斷是哪類文件,在調用對應的注釋監(jiān)測正則代碼段進行抓取,抓取到則行數+1,空白行也是一樣的原理,用strip(去除前后空格),然后行內內容為空則為空行,代碼段即為總行數減去其他兩類行數,最后在外層將所有文件對應的代碼段累加即為total

關鍵

函數內部是可以訪問全局變量的,問題在于函數內部修改了變量,導致python認為它是一個局部變量。

所以,如果在函數內部訪問并修改全局變量,應該使用關鍵字 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
#定義幾個全局變量用于計算所有文件總和(全部行數、代碼行數、空行數、注釋行數)
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
# 定義幾個全局變量用于計算每個文件行數(全部行數、代碼行數、空行數、注釋行數)
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))

關于python中怎么統(tǒng)計代碼行數就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。


分享標題:python中怎么統(tǒng)計代碼行數
網站網址:http://weahome.cn/article/johecj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部