鱼C论坛

 找回密码
 立即注册
查看: 818|回复: 7

[已解决]循环读取文本指定内容进行替换并写入新文本

[复制链接]
发表于 2020-5-26 19:23:43 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 菜鸟江湖 于 2020-5-26 19:31 编辑

我之前发过帖子最后还是没有解决,我用别的方式解决需求了,但是最近还是遇到问题还是需要想办法走老路解决,我想过用列表然后在读取但是太菜了没搞定,请各路大神帮忙看下怎么实现。
需求:
1、提取文本中两个"!"之间的内容(两个!之间的内容是跨行内容
2、对提取的对象进行处理,处理完成后写入新文本
3、循环第二步,直到文本读完
4、把没有math到的部分做标记也写入新文本
#txt内容为:
"""
!
spanning-tree mode mst
spanning-tree portfast bpduguard default
spanning-tree extend system-id
!
spanning-tree mst configuration
 name gmcc
 revision 2
 instance 1 vlan 1-4094
!
spanning-tree mst 1 priority 24576
diagnostic bootup level minimal
diagnostic cns publish cisco.cns.device.diag_results
diagnostic cns subscribe cisco.cns.device.diag_commands
fabric timer 15
!
vlan internal allocation policy ascending
vlan access-log ratelimit 2000
!
vlan 2
 name MMIntranet
!
vlan 3 
!
vlan 4
 name YiJiLouGuanLi
!
"""

#下面是我之前写的脚本,是逐行读取文本进行对象处理的
def match_1(new_filename,line_number,line):
#        sys.stdout.write("                              \r") 
#        sys.stdout.write("正在收集第"+line_number+"行!\r")
#一、全局替换"!"为"#"
        match_Obj_1 = re.match(r'^(!)\n, line, re.I)
        if match_Obj_1 != None:
                with open(new_filename, "a", encoding="UTF-8") as file:
                        file.write('#'+'\n')
                return
#二、替换vlan和vlan描述
        match_Obj_1=re.match(r'^vlan (\d)(.*),line,re.I)
        if match_Obj_1 != None :
                with open(new_filename,"a",encoding="UTF-8") as file :
                        file.write('vlan '+match_Obj_1.group(1)+re.sub(r',','\nvlan ',(re.sub(r'-',' to ',match_Obj_1.group(2))))+'\n')
                return
#十、将没有match到的line直接写入文本并添加注释"//"
        with open(new_filename,"a",encoding="UTF-8") as file :
                file.write("//"+line)
        return

#输入需要打开的文件和输出文件的名字
old_filename=input("请输入匹配文本名字\n") + ".txt"
old_filename1=old_filename + "_1.txt"
new_filename=old_filename + "_Translator.txt"
line_number=0
#之前遇到跨行内容我想出的解决办法,直接用re.sub替换
all_line=open(old_filename,"r").read()
with open(old_filename1,"a") as file:
        file.write(re.sub("switchport trunk encapsulation dot1q\n switchport mode trunk","switchport trunk encapsulation dot1q\n switchport trunk allowed vlan all\n switchport mode trunk",all_line))
#读取匹配文本 
with open(old_filename1,"r",encoding="UTF-8") as file :
        #把读取的每一行的数据和输入的文件名传递给 match_1 
        for line in file : 
                line_number = line_number + 1 
                match_1(new_filename,str(line_number),line)
print("\n脚本结束") 
input() 
#脚本结束
最佳答案
2020-5-26 21:08:02
本帖最后由 Twilight6 于 2020-5-26 21:09 编辑
菜鸟江湖 发表于 2020-5-26 21:05
我之前试过用正则,太菜了写不出来。。因为内容跨行处理不好失败了


看不懂你需求,你代码还带替换什么,需求都没写需要替换吧?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-5-26 20:11:47 | 显示全部楼层
用正则?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-26 20:29:19 | 显示全部楼层
漏上说的对
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-26 21:05:53 | 显示全部楼层

我之前试过用正则,太菜了写不出来。。因为内容跨行处理不好失败了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-26 21:08:02 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Twilight6 于 2020-5-26 21:09 编辑
菜鸟江湖 发表于 2020-5-26 21:05
我之前试过用正则,太菜了写不出来。。因为内容跨行处理不好失败了


看不懂你需求,你代码还带替换什么,需求都没写需要替换吧?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-26 21:34:31 | 显示全部楼层
Twilight6 发表于 2020-5-26 21:08
看不懂你需求,你代码还带替换什么,需求都没写需要替换吧?

需求:
1、提取文本中两个"!"之间的内容(两个!之间的内容是跨行内容)
2、对提取的对象进行处理,处理完成后写入新文本
3、循环第二步,直到文本读完
4、把没有math到的部分做标记也写入新文本
可以理解为这样:
import re
line=open("1.txt")
match_Obj_1 = re.match(r'!([.\n]*)!',line, re.MULTILINE)
if match_Obj_1 != None:
    print(match_Obj_1.group(1))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-28 17:02:49 | 显示全部楼层
菜鸟江湖 发表于 2020-5-26 21:34
需求:
1、提取文本中两个"!"之间的内容(两个!之间的内容是跨行内容)
2、对提取的对象进行处理,处理 ...

我想到办法解决了代码如下:
def text_pre_processing(old_filename1,temp_1,line):
    if line == "!\n":
        if "Ethernet" in ("".join(temp_1)) and  "ip address" in ("".join(temp_1)):
                print("match到Ethernet+ip address对象啦\n")
                with open(old_filename1, "a", encoding="utf-8") as file:
                    file.write("!\n"+re.sub(" ip address "," no switchport\n ip address ",("".join(temp_1)))+"!\n")
                conuter=0
                temp_1.clear()
        if "switchport mode trunk" in ("".join(temp_1)) and  "switchport trunk allowed vlan" not in ("".join(temp_1)):
                print("match到+trunk+没有allowed vlan对象啦\n")
                with open(old_filename1, "a", encoding="utf-8") as file:
                    file.write("!\n"+re.sub(" switchport mode trunk"," switchport mode trunk\n switchport trunk allowed vlan all",("".join(temp_1)))+"!\n")
                conuter=0
                temp_1.clear()
        else:
            print("没有match到对象,正常输出")
            with open(old_filename1, "a", encoding="utf-8") as file:
                file.write("!\n"+"".join(temp_1)+"!\n")
            conuter=0
            temp_1.clear()
    else:
        temp_1.append(line)

#输入需要打开的文件和输出文件的名字
old_filename=input("请输入匹配文本名字\n") + ".txt"
old_filename1=old_filename + "_1.txt"
new_filename=old_filename + "_Translator.txt"
line_number=0
conuter=0
temp_1=[]

#读取匹配文本进行预处理并生成预处理文件old_filename1
with open(old_filename,"r",encoding="UTF-8") as file :
        #把读取的每一行的数据和输入的文件名传递给 match_1
        for line in file :
                line_number = line_number + 1
                text_pre_processing(old_filename1,temp_1,line)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-28 17:07:23 | 显示全部楼层
人在家中睡,最佳天上来???我喜欢,再来一打
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-21 00:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表