本文实例为大家分享了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))
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年09月21日
2024年09月21日
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- 任天堂今晚举行直面会!第三方及独立游戏展示
- 《哆啦A梦的铜锣烧店物语》发售!开罗公式+哆啦A梦
- 任天堂公布《塞尔达传说》系列时间线:野炊与王泪独立在外
- 五条人.2012-一些风景2CD【刀马旦】【WAV+CUE】
- 陈奕迅.2013-Easons.Life演唱会2CD(2024环球红馆40复刻系列)【环球】【WAV+CUE】
- 许美静.1995-遗憾(新马版)【上华】【WAV+CUE】
- 《叶倩文 歌声情缘》[WAV+CUE][410MB]
- 《张国荣 首首动听经典不容错过 追忆的风 2CD》[WAV+CUE][870MB]
- 《腾格尔 容中尔甲 亚东 高原三星 男人篇 3CD》[WAV/分轨][1GB]
- 命运圣契公测实测可用兑换码大全 命运圣契最新兑换码分享
- 黑神话悟空上品疾蝠精魄获取方法一览|上品疾蝠精魄收集攻略
- 《七龙珠电光炸裂!ZERO》GT角色预告片曝光,15位新角色登场
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- NewViennaOctetViennaWindSoloists-TheDeccaRecordings(2024)18CD[24-48][FLAC]-7