python遍历读取txt文件夹,正则匹配获取目标字段,去除重复写入txt文档

  • 思路:首先遍历循环文件夹,输出地址判断是否读对了文件,读取出文件中的内容,用正则匹配的模式匹配匹配出对应的字段,将两个匹配出来的列表字段合并,去重,写入目标文件夹中。
import re # 导入正则包
import os

path = "D:\腾讯QQ\QQ下载\资源"  # 文件夹目录
files = os.listdir(path) # 读取文件夹目录
allresult = [] # 定义空列表
for file in files:  # 遍历文件夹
    position = path + '\\' + file  # 构造绝对路径,"\\",其中一个'\'为转义符
    print(position)
    f = open(position, "r", encoding='utf-8')  # 设置文件对象
    data = f.readlines()  # 直接将文件中按行读到list里,效果与方法2一样
    pattern = re.compile('rsas_.\S*') # 匹配从rsas开始,到空格处结束的内容
    result = pattern.findall(str(data)) # 模式匹配方法,找到所有模式为pattern的字段
    pattern2 = re.compile('RSAS_.\S*')
    result2 = pattern2.findall(str(data))
    allresult = allresult + result + result2 # 两个模式为去除来的列表合并
    f.close() # 关闭数据流
print(set(allresult)) # 字段去重
file = open('D:\腾讯QQ\QQ下载\表--多条去除.txt', 'w', encoding='utf-8')
file.write(str(set(allresult))) # 将文件写入目标文件夹
file.close() # 关闭数据流

你可能感兴趣的:(python,python,正则表达式,去重,python读写文件)