鱼C论坛

 找回密码
 立即注册
查看: 1938|回复: 4

[已解决]新人求助

[复制链接]
发表于 2017-10-14 18:26:31 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
从零学习python课程中的源代码如下:
import easygui as g
import os


def show_result(start_dir):
    '显示结果'
    lines = 0
    total = 0
    text = ""

    for i in source_list:
        lines = source_list[i]
        total += lines
        text += "【%s】源文件 %d 个,源代码 %d 行\n" % (i,file_list[i],lines)
    title = '统计结果'
    msg = '您目前共累积编写了 %d 行代码,完成进度:%.2f %%\n离 10 万行代码 %d 行,请继续努力!' % (total,total/1000,100000-total)
    g.textbox(msg,title,text)


def calc_code(file_name):
    '统计源文件里的代码行数'
    lines = 0
    with open(file_name,'rb') as f:
        print('正在分析文件:%s ...' % file_name)
        try:
            for each_line in f:
                lines += 1
        except UnicodeDecodeError:
            pass # 不可避免会遇到格式不兼容的文件,这里忽略掉...
    return lines


def search_file(start_dir):
    os.chdir(start_dir)

    for each_file in os.listdir(os.curdir):
        ext = os.path.splitext(each_file)[1]
        if ext in target:
            lines = calc_code(each_file)    #统计行数
            #还记得异常的用法吗?如果字典中不存,抛出KeyError,则添加字典键
            #统计文件数
            try:
                file_list[ext] += 1
            except KeyError:
                file_list[ext] = 1
            #统计源代码行数
            try:
                source_list[ext] += lines
            except KeyError:
                source_list[ext] = lines


        if os.path.isdir(each_file):
            search_file(each_file) #递归调用
            os.chdir(os.pardir) #递归调用后切记返回上一层目录


#程序执行
target = ['.c','.cpp','.py','.cc','.java','.pas','.asm']
file_list = {}  #用于存放源文件个数
source_list = {}    #用于存放源文件代码行数

g.msgbox("请打开您存放所有代码的文件夹...","统计代码量")
path = g.diropenbox("请选择您的代码库:")

search_file(path)
show_result(path)


问题:
在统计代码行数时,怎么实现只统计代码不统计注释呢?
最佳答案
2017-10-14 21:48:51
把这段改一下:
  1. def calc_code(file_name):
  2.     '统计源文件里的代码行数'
  3.     lines = 0
  4.     with open(file_name,'rb') as f:
  5.         print('正在分析文件:%s ...' % file_name)
  6.         try:
  7.             for each_line in f:
  8.                 if each_line[0] != '#':
  9.                     lines += 1
  10.         except UnicodeDecodeError:
  11.             pass # 不可避免会遇到格式不兼容的文件,这里忽略掉...
  12.     return lines
复制代码

但是不同语言的注释符不一样,要分别处理,另像三引号的注释要分别考虑开始和结束。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-10-14 18:50:14 | 显示全部楼层
首先要找待注释符号。比如Python里的注释是以#开始的行
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-10-14 20:45:09 | 显示全部楼层
堕落之翼 发表于 2017-10-14 18:50
首先要找待注释符号。比如Python里的注释是以#开始的行

可以详细说说吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-10-14 21:48:51 | 显示全部楼层    本楼为最佳答案   
把这段改一下:
  1. def calc_code(file_name):
  2.     '统计源文件里的代码行数'
  3.     lines = 0
  4.     with open(file_name,'rb') as f:
  5.         print('正在分析文件:%s ...' % file_name)
  6.         try:
  7.             for each_line in f:
  8.                 if each_line[0] != '#':
  9.                     lines += 1
  10.         except UnicodeDecodeError:
  11.             pass # 不可避免会遇到格式不兼容的文件,这里忽略掉...
  12.     return lines
复制代码

但是不同语言的注释符不一样,要分别处理,另像三引号的注释要分别考虑开始和结束。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-10-15 13:15:44 | 显示全部楼层
冬雪雪冬 发表于 2017-10-14 21:48
把这段改一下:

但是不同语言的注释符不一样,要分别处理,另像三引号的注释要分别考虑开始和结束。

好的 谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-3-3 02:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表