快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

统计python代码行数-创新互联

   addhosts项目已接近尾声,我很想知道我们写了多少行代码。

成都创新互联网站建设公司是一家服务多年做网站建设策划设计制作的公司,为广大用户提供了网站制作、网站建设,成都网站设计,一元广告,成都做网站选成都创新互联,贴合企业需求,高性价比,满足客户不同层次的需求一站式服务欢迎致电。

一、需求

   统计源码目录下py文件的代码行数。

   统计python代码行数

二、脚本分析

   获取指定目录下所有的.py文件,对文件进行遍历;

   读取每个文件,对文件内容进行遍历,过滤掉空行和注释;

三、实现及结果

#coding:utf-8
import os

class StatLines(object):

    def __init__(self,path):
        self.path = path

    def stat_lines(self):
        file_list = os.listdir(self.path)
        os.chdir(self.path)
        total = 0
        for file in file_list:
            if file.endswith('.py'):
                lines = open(file, encoding='utf-8').readlines()
                count = 0
                for line in lines:
                    if line == '\n':
                        continue
                    elif line.startswith('#'):
                        continue
                    else:
                        count += 1
                total += count
                print('%s has %d lines' %(file,count))
        print('total lines is: %d' %total)

if __name__ == '__main__':
    sl = StatLines('E:\\Python_Project\\addhost_v2\\addhosts')
    sl.stat_lines()

运行结果如下:

统计python代码行数

四、总结

   问题:

   在执行open(file).readlines()时,遇到了如下错误

“UnicodeDecodeError: 'gbk' codec can't decode byte 0xaf in position 548: illegal multibyte sequence”

   解决方法:

   在open时,设置encoding='utf-8'后,问题得到解决。


本文题目:统计python代码行数-创新互联
文章位置:http://6mz.cn/article/idhij.html

其他资讯