python在多个文本中正则匹配并写入到xlsx文件

        作为网工在项目中经常能需要在现网几千台配置文件中,梳理某个业务情况的场景,那么如下就是根据现有配置文件,使用python正则匹配,来找到指定需要的结果,并输出到excel中。

举例: 查找文件夹下所有文件里面包含 “ peer x.x.x.x as-number 12345” 的行,并记录文件名和该行配置到excel文件中,该例中配置文件夹名为“MP”,输出的excel为output.xlsx 页为all,其中A列记录文件名,B列记录匹配的配置。

import os
import re
import sys
import xlwings as xlw
import pandas as pd

input_wb = None
work_sheet = None
row_count = 0

# 打开Excel程序,APP不可见,屏幕更新关闭
app = xlw.App(visible=False, add_book=False)
# Excel工作簿显示警告,不显示
app.display_alerts = False
# 工作簿屏幕更新,不更新
app.screen_updating = False

#
xls_file = "output.xlsx"
xls_file_sheet = "all"
# 打开excel文件
input_file_path = os.path.join(os.getcwd(), xls_file)
#
if os.path.exists(input_file_path):
    input_wb = app.books.open(input_file_path)
# 获取输入活动页sheet
work_sheet = input_wb.sheets[xls_file_sheet]
#
s = '^  peer ([^\n])*as-number 12345$\n'
re_m = re.compile(s, re.I | re.S | re.M)
#

for root, dirs, files in os.walk(os.path.join(os.getcwd(), "MP")):
    # print("当前目录:", root)
    # print("子目录列表:", dirs)
    # print("文件列表:", files)
    #
    # 遍历文件夹内文件,找到cfg文件
    #
    # if any((match := re_cfg_file.search(item)) for item in files):
    for item in files:
        cfg_file = os.path.join(root, item)
        # print(cfg_file)
        f = open(cfg_file, 'r')
        lines = f.read()
        m = re.finditer(re_m, lines)
        if not m:
            print('Fail Match')
        else:
            for x in m:
                work_sheet.range("A" + str(i)).value = item
                work_sheet.range("B" + str(i)).value = x.group(0).replace('\n', '')
                i = i + 1
        f.close()
# 设置列宽 行高
work_sheet.range("A1").expand(mode='table').autofit()
work_sheet.range("A1").expand(mode='table').row_height = 14.3
input_wb.save(input_file_path)
input_wb.close()
#
app.quit()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值