日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

python實(shí)現(xiàn)統(tǒng)計(jì)代碼行數(shù)的小工具

系統(tǒng) 1821 0

一個(gè)用python實(shí)現(xiàn)的統(tǒng)計(jì)代碼行數(shù)的小工具,供大家參考,具體內(nèi)容如下

實(shí)現(xiàn)功能

  • 計(jì)算出某一目錄以及子目錄下代碼文件的行數(shù)
  • 在計(jì)算代碼的過(guò)程中,只對(duì)標(biāo)準(zhǔn)命名的文件進(jìn)行統(tǒng)計(jì),如[文件名.文件類型]
  • 排除了以“#”開(kāi)頭的包含文件,宏定義等,如#include, #define, #pragma等
  • 排除了c,cpp文件中的“//”, “/…/”等的注釋
  • 排除了python文件中import, from 等開(kāi)頭的導(dǎo)入

使用方法

新建countLines.py文件,復(fù)制代碼到文件中,將其放在想計(jì)算行數(shù)的代碼目錄下,直接使用Python運(yùn)行即可算出該目錄以及所有子目錄下代碼文件的行數(shù)。

1.將該python文件命名為countLines.py,放到想計(jì)算代碼行數(shù)的文件目錄下

python實(shí)現(xiàn)統(tǒng)計(jì)代碼行數(shù)的小工具_(dá)第1張圖片

2.其中helloworld.c文件內(nèi)容如下:

python實(shí)現(xiàn)統(tǒng)計(jì)代碼行數(shù)的小工具_(dá)第2張圖片

3.用python.exe直接打開(kāi)該文件或者使用python countLines.py,運(yùn)行文件即可。?

python實(shí)現(xiàn)統(tǒng)計(jì)代碼行數(shù)的小工具_(dá)第3張圖片

我們可以看到,統(tǒng)計(jì)代碼行的時(shí)候我們排除了兩個(gè)空行以及開(kāi)頭的包含文件行,因此有效代碼行為5行

代碼實(shí)現(xiàn)

            
#!/usr/bin/env python
# -- coding: utf-8 --
# @Time : 2018/3/5 13:55
# @Author : likewind
# @mail : likewind1993@163.com
# @File : countLines.py
# @Software: sky-studio.cn
import os
'''
返回每個(gè)文件行數(shù),其中行數(shù)不包括以“#”開(kāi)頭的包含文件,宏定義等,
排除了c,cpp文件中的“//”, “/*...*/”等的注釋,
排除了python文件中import, from 等開(kāi)頭的導(dǎo)入
'''

def get_lines(file_name):
 f = open(file_name)
 #flag用于處理c,cpp中“/*...*/”多行注釋
 flag = False
 count = 0
 while True:
  #讀取文件并去除開(kāi)頭的空格,制表符
  line = f.readline()
  line = line.lstrip(' \t')
  if not line:
   break
  #如果該行有“#”, “import”等打頭的字符,忽略該行
  if flag == False:
   if line[0:1] == "#" or line[0:6] == "import" or line[0:4] == "from" or line == "\n" or line[0:2] == "http://":
    continue
  #如果該行存在“/*”并且不存在“*/”,表明多行注釋未在一行結(jié)束,flag=True
  if line.find("/*") != -1 :
   if line.find("*/") != -1:
    continue
   else:
    flag = True
    continue
  #如果flag=True,表明處于多行注釋中,判斷是否有“*/”結(jié)尾
  if flag == True :
   if line.find("*/") != -1:
    flag = False
    if line[-2:] != "*/":
     count = count+1
   continue
  #排除以上條件后,行數(shù)增加一
  count = count+1
 f.close()
 return count
'''
計(jì)算該文件目錄下所有符合條件的行數(shù)
'''
def count_lines(file_dir):
 #total_lines表示總行數(shù),file_nums表示總文件數(shù)
 total_lines = 0
 file_nums = 0
 for root, dirs, files in os.walk(file_dir):
  for file in files:
   #不計(jì)算本文件的行數(shù)
   if file == "countLines.py":
    continue
   #只計(jì)算規(guī)范命名文件, 如[文件名.文件類型]
   file_type = file.split('.')
   if len(file_type) > 1 :
    #如果想計(jì)算其他類型的文件,可以在這里進(jìn)行修改
    if file_type[1] not in ["py", "c", "cc", "cpp", "h"]:
     continue
   else:
    continue
   file_name = root +"\\" + file
   lines = get_lines(file_name)
   total_lines = total_lines + lines
   print file_name + " contains lines : " + repr(lines)
   file_nums = file_nums + 1
 #輸出結(jié)果
 print "------------------------------------"
 print "Total Files : " + repr(file_nums)
 print "Total lines : " + repr(total_lines)
 print "------------------------------------"

if __name__ == '__main__':
 cur_path = os.path.split(os.path.realpath(__file__))[0]
 count_lines(cur_path)
 raw_input("Press any key to exit...")
          

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 十堰市| 宁城县| 顺昌县| 厦门市| 景东| 靖安县| 谷城县| 府谷县| 安多县| 新昌县| 武夷山市| 阿克| 元阳县| 崇明县| 黑龙江省| 波密县| 莱芜市| 广丰县| 博白县| 定安县| 呼伦贝尔市| 通辽市| 张家口市| 汤阴县| 什邡市| 双鸭山市| 沅江市| 密山市| 晴隆县| 平乐县| 晋宁县| 武乡县| 山阴县| 盐山县| 江北区| 浑源县| 武宣县| 哈巴河县| 贵溪市| 东乌珠穆沁旗| 芒康县|