时间:2021-05-22
需求:程序开发中有大量的接口,但在实际的使用中有一部分是没有使用的,在开发的程序中匹配这些接口名,找到哪些接口从没有使用过。将这些没有使用过的接口名保存下来。
代码结构:
结构解析:
1、find.py 是文件查找及匹配程序
2、input_files.txt是待匹配内容
文件格式如下:
3、result.txt 用于存放查找结果
格式同上
4、text.txt 用于测试的文档(可忽略)
实际代码:
find.py
#!/usr/bin/python# -*- coding: UTF-8 -*-import os, re, datetimeclass Find(object): def __init__(self, root, input_file): """ --初始化 """ self.root = root # 文件树的根 self.input_files = [] # 待查询的字符串集合 self.files = [] # 待匹配的文件集合 self.current = 0 # 正在匹配的文件集合的位置 f = file(input_file, "r") old_content = f.read() f.close() self.input_files = old_content.split('\n') # 将待匹配字符串保存在数组中 @staticmethod def find_file(self): """ --查找文件,即遍历文件树将查找到的文件放在文件集合中 :return: """ # python中的walk方法可以查找到所给路径下的所有文件和文件夹,这里只用文件 for root, dirs, files in os.walk(self.root, topdown=True): for name in files: self.files.append(os.path.join(root, name)) # print(os.path.join(root, name)) # for name in dirs: # print(os.path.join(root, name)) @staticmethod def walk(self): """ --逐一查找,并将结果存入result.txt文件中 :param self: :return: """ for item1 in self.files: Find.traverse_file(self, item1) try: result = '' for item3 in self.input_files: result += item3 + '\n' f = file("./result_files.txt", "w") f.write(result) f.close() except IOError, msg: print "Error:", msg else: print "OK" @staticmethod def traverse_file(self, file_path): """ --遍历文件,匹配字符串 :return: """ f = file(file_path, "r") file_content = f.read() f.close() input_files = [] for item2 in self.input_files: if item2: # 正则匹配,不区分大小写 searchObj = re.search(r'(.*)' + item2 + '.*', file_content, re.M | re.I) if searchObj: continue else: input_files.append(item2) self.input_files = input_filesif __name__ == "__main__": print datetime.datetime.now() findObj = Find('F:\\projects', "./input_files.txt") findObj.find_file(findObj) findObj.walk(findObj) print datetime.datetime.now()以上这篇python 文件查找及内容匹配方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一般来说,宠物词的产生有三个方面的原因:1。修改匹配方法;2.时间和地区选择;3.一、修改匹配方法表达3大匹配方法,短语匹配/切分词匹配/精确匹配。在流动质量方
只知道头像不能查找qq号。腾讯QQ是不提供根据头像检索的,因为头像查找的方法要通过识图来匹配,这种匹配方式的准确率太低。 QQ是腾讯QQ的简称,是一款基于In
淘宝商家开通了直通方式以后需要去选择匹配方式,而淘宝直通车的匹配方式分为了很多种,很多的淘宝新手商家不知道如何选择。下面的内容了解一下淘宝直通车的匹配方式在哪里
Python四种逐行读取文件内容的方法下面四种Python逐行读取文件内容的方法,分析了各种方法的优缺点及应用场景,以下代码在python3中测试通过,pyth
本文实例讲述了Python时间的精准正则匹配方法。分享给大家供大家参考,具体如下:要用正则表达式精准匹配时间,其实并不容易方式一:>>>importre>>>t