python如何實現代碼統計程序-創新互聯

創新互聯公司是一家專業提供祁縣企業網站建設,專注與成都網站設計、網站制作H5開發、小程序制作等業務。10年已為祁縣眾多企業、政府機構等服務。創新互聯專業的建站公司優惠進行中。

這篇文章將為大家詳細講解有關python如何實現代碼統計程序,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

# encoding="utf-8"

"""
統計代碼行數
"""

import sys
import os

def count_file_line(path):
 """統計文件的有效行數"""
 countLine = 0
 # 設置一個標志位,當遇到以"""或者'''開頭或者結尾的時候,置為False
 flag = True

 # 使用utf-8格式的編碼方式讀取文件,如果讀取失敗,將使用gbk編碼方式讀取文件
 try:
 fp = open(path, "r", encoding="utf-8")
 encoding_type = "utf-8"
 fp.close()
 except:
 encoding_type = "gbk"

 with open(path, "r", encoding=encoding_type) as fp:
 for line in fp:
  # 空行不統計
  if line.strip():
  line = line.strip()
  # 注意下面的這兩個elif必須要前面,這樣子當('"""')結束之后及時將flag置為True
  if line.endswith('"""') and flag == False:
   flag = True
   continue
  if line.endswith("'''") and flag == False:
   flag = True
   continue
  if flag == False:
   continue
  if line.startswith("#!") or line.startswith("#-*-") or line.startswith("# encoding"):
   countLine += 1
  # 如果以“#”號開頭的,不統計
  elif line.startswith("#"):
   continue
  # 如果同時以("'''")或者('"""')開頭或者結尾(比如:"""aaa"""),那么不統計
  elif line.startswith('"""') and line.endswith('"""') and line != '"""':
   continue
  elif line.startswith("'''") and line.endswith("'''") and line != "'''":
   continue
  # 如果以("'''")或者('"""')開頭或者結尾(比如:aaa"""或者"""bbb),那么不統計
  # 注意下面的這兩個elif必須要放后面
  elif line.startswith('"""') and flag == True:
   flag = False
   continue
  elif line.startswith("'''") and flag == True:
   flag = False
   continue
  else:
   countLine += 1
 return countLine

def count_codes(path,file_types=[]):
 """統計所有文件代碼行"""
 # 判斷path是目錄還是文件,如果是目錄的話,遍歷目錄下所有的文件
 if not os.path.exists(path):
 print("您輸入的路徑不存在!")
 return 0
 countTotalLine = 0
 file_paths = {}
 if os.path.isdir(path):
 for root,dirs,files in os.walk(path):
  for name in files:
  if not file_types:
   file_types = ["txt","py"]
   # print(file_types)
  if os.path.splitext(name)[1][1:] in file_types:
   file_path = os.path.normpath(os.path.join(root,name))
   # print(file_path)
   file_lines = count_file_line(file_path)
   countTotalLine += file_lines
   file_paths[file_path] = file_lines
 else:
 if not file_types:
  file_types = ["txt","py"]
 if os.path.splitext(path)[1][1:] in file_types:
  countTotalLine = count_file_line(path)
  file_paths[path] = count_file_line(path)

 return countTotalLine,file_paths


if __name__ == "__main__":
 # 打印出命令行輸入的參數
 # print(sys.argv)
 if len(sys.argv) < 2:
 print("請輸入路徑!")
 sys.exit()
 path = sys.argv[1]
 # print(path)
 file_types = sys.argv[2:]
 # print(file_types)
 print(count_codes(path,file_types))

關于“python如何實現代碼統計程序”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

本文題目:python如何實現代碼統計程序-創新互聯
網頁路徑:http://m.kartarina.com/article48/ccggep.html

成都網站建設公司_創新互聯,為您提供軟件開發全網營銷推廣營銷型網站建設網站營銷ChatGPT動態網站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

h5響應式網站建設
主站蜘蛛池模板: 亚洲AV无码专区亚洲AV伊甸园| 亚洲国产精品无码中文字| 精品人妻无码专区中文字幕| 少妇精品无码一区二区三区 | 无码人妻少妇伦在线电影| 亚洲aⅴ无码专区在线观看春色 | 亚洲日韩激情无码一区| 日韩精品少妇无码受不了| 亚洲av午夜精品无码专区| 亚洲AV无码成人精品区日韩| 国产成人无码免费网站| 免费无遮挡无码永久视频| 精品久久久无码中字| 亚洲av永久无码制服河南实里| 亚洲一级特黄无码片| 久久无码无码久久综合综合 | 日韩亚洲AV无码一区二区不卡| 日韩国产成人无码av毛片| 国产精品无码无卡无需播放器| 成人无码午夜在线观看| 曰产无码久久久久久精品 | 中文字幕AV中文字无码亚| 永久免费av无码不卡在线观看| 人妻在线无码一区二区三区| 曰批全过程免费视频在线观看无码| 亚洲AV无码国产精品麻豆天美| 亚洲成a人无码亚洲成www牛牛| 国产成人无码网站| 久久精品无码一区二区WWW| 国模吧无码一区二区三区| 麻豆精品无码国产在线果冻| 高h纯肉无码视频在线观看| 秋霞鲁丝片无码av| 蜜臀AV无码精品人妻色欲| 久久久无码精品亚洲日韩京东传媒| 亚洲一级特黄无码片| 免费无码成人AV片在线在线播放| 无码人妻精品一区二区三区66| 亚洲AV成人无码网站| 无码人妻丰满熟妇区BBBBXXXX| 精品久久久久久无码人妻热 |