午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Python 遍歷文件夾,統計所有不同后綴的文件數量與比例

瀏覽:196日期:2022-08-21 15:31:08

問題描述

在Github上經常看到項目里不同語言的占比,突然想寫一個試試。

Python 遍歷文件夾,統計所有不同后綴的文件數量與比例

自己寫完一個殘缺的,感覺肯定不是最優解,所以來請教大家的寫法。謝謝。

!/usr/bin/env pythoncoding:utf-8

import os

if name == ’__main__’:

work_space = os.getcwd()pycount = 0javacount = 0jscount = 0wecount = 0othercount = 0total = 0print work_spaceprint ’正在計算比例,請稍候.....’.decode(’utf-8’)for path, dir, file_arr in os.walk(’./’): for file_name in file_arr:javasuffix = file_name[-5:]pysuffix = file_name[-3:]if cmp(pysuffix, ’.py’) == 0: pycount += 1elif cmp(pysuffix, ’.js’) == 0: jscount += 1elif cmp(javasuffix, ’.java’) == 0: javacount += 1elif cmp(pysuffix, ’.we’) == 0: wecount += 1else: othercount += 1total = pycount + jscount + javacount + wecount + othercounttotal = float(total)print ’計算完成: 總文件數 : %d ’.decode(’utf-8’) % totalprint ’文件數 Java: %d js: %d py: %d we: %d others: %d ’.decode(’utf-8’) % ( javacount, jscount, pycount, wecount, othercount)print ’所占比例 Java: %.2f%% js:%.2f%% py:%.2f%% we:%.2f%% others:%.2f%%’.decode(’utf-8’) % ( javacount / total * 100, jscount / total * 100, pycount / total * 100, wecount / total * 100, othercount / total * 100)

問題解答

回答1:

#coding: utf-8import osfrom itertools import groupbyfile_lst = []for path, dir, files in os.walk(’./’): file_lst += filesfile_count = len(file_lst) * 1.0for key, lst in groupby(file_lst, key=lambda x: os.path.splitext(x)[1]): print key, round(len(list(lst))/file_count, 2)

看第二種:

#coding: utf-8import osfrom collections import defaultdictfile_count = 1.0res = defaultdict()for path, dir, files in os.walk(’./’): file_count += len(files) for file in files:suf = os.path.splitext(file)[1]res[suf] = res.setdefault(suf, 0) + 1for k, v in res.iteritems(): print k, round(v/file_count, 4) * 100回答2:

改進后的

# coding: utf-8import osfrom itertools import groupbydef getpercent(num): return str(round(num / file_count * 100, 2))def getresult(): for key in language_dict:print ’%s count:%d percent:%s%%’ % (key, language_dict.get(key), getpercent(language_dict[key]))if __name__ == ’__main__’: file_lst = [] language_dict = {} for path, dirs, files in os.walk(’./’):file_lst += files file_count = len(file_lst) * 1.0 for key, lst in groupby(file_lst, key=lambda x: os.path.splitext(x)[1]):if key not in language_dict.keys(): language_dict[key] = len(list(lst))else: language_dict[key] = language_dict.get(key) + len(list(lst)) getresult()

標簽: Python 編程
主站蜘蛛池模板: 欧美v在线| 亚洲69av | 国产日产亚洲精品 | 青青草伊人网 | 成年人网站免费在线观看 | 日韩中文字幕一区二区三区 | 黑人操亚洲人 | 成人动漫中文字幕 | 午夜免费在线观看 | 天天干天天添 | 欧美三级中文字幕 | 欧美区日韩区 | 97av在线视频 | 国产最新在线视频 | 久久国产免费观看 | 国产一区二区亚洲 | 婷婷精品在线 | 国产精品久久免费视频 | 高清一区二区 | 中文字幕在线资源 | 欧美日韩精品久久久 | 国产黄色免费大片 | 国产精品久久久网站 | 日韩午夜影院 | 欧美日韩色综合 | 国产区精品在线 | 一级成人毛片 | 国产一区二区三区在线视频 | 欧美精品亚洲精品 | 日韩天堂在线 | 美女网站在线看 | 日韩av成人在线观看 | 91看片免费版| 精品视频久久久久 | 免费一级做a爰片久久毛片潮 | 91精品在线播放 | 亚洲国产欧美日韩在线 | 欧美美女啪啪 | 超碰免费97 | 伊人久综合 | 天天狠狠 |