通常自动化测试项目到了一定的程序,编写的测试代码自然就会很多,如果很早已经编写的测试脚本现在某些基础函数、业务函数需要修改,那么势必要找出那些引用过这个被修改函数的地方,有些IDE支持全文查找和引用查找,而有些简单的可能就没有,因为日后要用到统计功能、和一些其它的需求,所以写了一个脚本。除了跟目录下全文查找引用过的文件外,还是支持统计查找到的数量,一次可以查找多个关键字,支持按主关键字来归类。
#encoding: utf-8 import os import sys import re reload(sys) sys.setdefaultencoding("utf-8") short_exclude = [".svn", "sendbox"] ##不检查的文件、目录名 long_exclude = [] ##不包含检查的文件、目录的完整路径 extend_name = [".rb"] ##指定检查的文件后缀 temp_key_words = [ { "key" : "#作者:", "display" : "作者", "times" : -1, "match" : "include", "primary_key" : True, }, { "key" : "#[summary]", "display" : "完成用例数", "times" : -1, "match" : "include", }, { "key" : "File.expand_path", "display" : "有状态行数", "times" : -1, "ignore_case" : True, }, { "key" : "def\s+test_", "display" : "有效用例数", "times" : -1, "match" : "regex", "ignore_case" : True, }, { "key" : "#def\s+test_", "display" : "注释用例数", "times" : -1, "match" : "regex", "ignore_case" : True, }, ] for kv in temp_key_words: if not "key" in kv: raise "以下的列表中没有【key】值!\n%s" % kv if not "key" in kv: raise "以下的列表中没有【display】值!\n%s" % kv kv['times'] = kv.get('times', -1) ##默认为不限制检查次数 if kv.get("ignore_case", True)==False: ##默认忽略大小写 flag = 0 else: flag = re.I kv['pattern'] = re.compile(kv['key'], flag) if kv.get("primary_key", False): kv['times'] = 1 import copy key_words = [] def deepcopy(objs): t_list = [] for obj in objs: t_list.append(copy.copy(obj)) return t_list def loop_case(root_dir): t_sum = [] print root_dir sub_gen = os.listdir(root_dir) for sub in sub_gen: if sub in short_exclude: ##在不检查文件、目录范围中 continue abs_path = os.path.join(root_dir, sub) if long_exclude: is_exclude = False for exclude in long_exclude: if exclude == abs_path[-len(exclude):]: is_exclude = True break if is_exclude: continue print abs_path if os.path.isdir(abs_path): print "dir" t_sum.extend(loop_case(abs_path)) elif os.path.isfile(abs_path): if not "." + abs_path.rsplit(".", 1)[1] in extend_name: ##不在后缀名 检查范围中 continue print "file" global key_words key_words = deepcopy(temp_key_words) t_sum.append(count_case(abs_path)) return t_sum def count_case(abs_path): t_dict = {} with open(abs_path) as f: for l in f: l = l.strip() match_rule(l) index = 0 count_result = [0] * len(key_words) for kv in key_words: if 'primary_key' in kv: t_dict['primary_key'] = kv.get('display') t_dict['primary_key_value'] = kv.get('primary_key_value', "None") count_result[index] = -1-kv['times'] index += 1 t_dict['match_result'] = count_result t_dict['file_path'] = abs_path return t_dict def match_rule(line): primary_key = None for kv in key_words: match = False if kv['times']==0: ##检查次数已满,不再检查 continue if kv.get('match', "") == "regex": ##指定了匹配方式为:正则 if kv['pattern'].match(line): ##匹配正则成功 match = True else: ##默认匹配方式为: 包含 if kv['key'] in line: ##包含了指定字符串 match = True if match: if kv.get('primary_key', False): kv['primary_key_value'] = line.split(kv['key'])[1].strip() # kv['primary_key'] = False kv['times'] -= 1 ##匹配成功,同理剩余匹配的次数 -1 return primary_key def format_info(sum_list): tip_list = [] p_k_dict = {} for d in sum_list: p_k = d['primary_key_value'] if p_k not in p_k_dict: p_k_dict[p_k] = [0] * len(key_words) temp_list = [] m = d['match_result'] temp_list.append("文件名称:%s\n%s:%s\n" % (d['file_path'], d['primary_key'], d['primary_key_value'])) for i in range(len(m)): if 'primary_key' in key_words[i]: continue else: t_s = str(m[i]) temp_list.append("%s:%s\n" % (key_words[i]["display"], t_s)) p_k_dict[p_k][i] += m[i] tip_list.append("".join(temp_list)) p_k_dict[p_k][0] += 1 tip_list.append("===========================主键统计分割线===============================") total_dict = {} for kv in key_words: if 'primary_key' not in kv: total_dict[kv['display']] = 0 total_dict['全部文件数'] = 0 for k,v in p_k_dict.items(): temp_list = [] temp_list.append("主键:%s\n文件总数:%s\n" % (k, v[0])) for i in range(1, len(v)): temp_list.append("%s:%s\n" % (key_words[i]["display"], str(v[i]))) total_dict[key_words[i]["display"]] += v[i] tip_list.append("".join(temp_list)) total_dict['全部文件数'] += v[0] tip_list.append("===========================全部统计分割线===============================") temp_list = [] for k,v in total_dict.items(): temp_list.append("全部%s:%s\n" % (k,v)) tip_list.append("".join(temp_list)) tip_msg = "\n".join(tip_list) print tip_msg open(r"sum_case.log", "w").write(tip_msg) if __name__=="__main__": if len(sys.argv) > 1: root_list = sys.argv[1:] else: root_list = [os.curdir] sum_list = [] for root_dir in root_list: if os.path.exists(root_dir) and os.path.isdir(root_dir): sum_list.extend(loop_case(root_dir)) format_info(sum_list) else: print "给定的根目录无效\n%s" % root_dir
可以通过配置开头的设置来确定检查什么关键字,文件类型,过滤哪些文件和目录等
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“编写Python小程序来统计测试脚本的关键字”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
2025年01月11日
2025年01月11日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]