华南俳烁实业有限公司

python

當前位置:中華考試網(wǎng) >> python >> python編程基礎 >> 文章內(nèi)容

python3中的代碼行數(shù)是怎么計算的?

來源:中華考試網(wǎng)  [2020年12月1日]  【

  作為一個編程人員,每天除了測試外,很大一部分的時間都在敲代碼中度過。那么有沒有人想過我們寫的代碼到底有多少行呢?逐條去查數(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技術高薪工作機會唾手可得。

責編:fushihao
  • 會計考試
  • 建筑工程
  • 職業(yè)資格
  • 醫(yī)藥考試
  • 外語考試
  • 學歷考試
哈巴河县| 尚义县| 汶上县| 鄂伦春自治旗| 远安县| 潞西市| 阳曲县| 大名县| 银川市| 临沧市| 东山县| 山东| 龙游县| 灵寿县| 万山特区| 遂昌县| 丹棱县| 临泉县| 巫溪县| 宁陕县| 深州市| 苏尼特右旗| 确山县| 镇安县| 剑河县| 卓尼县| 康马县| 敦煌市| 宁武县| 额尔古纳市| 双峰县| 泰兴市| 景宁| 三台县| 东明县| 土默特右旗| 阿鲁科尔沁旗| 贺兰县| 永和县| 舞钢市| 太白县|