菜鸟江湖 发表于 2020-5-26 19:23:43

循环读取文本指定内容进行替换并写入新文本

本帖最后由 菜鸟江湖 于 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()
#脚本结束

Twilight6 发表于 2020-5-26 20:11:47

用正则?

Stubborn 发表于 2020-5-26 20:29:19

漏上说的对

菜鸟江湖 发表于 2020-5-26 21:05:53

Twilight6 发表于 2020-5-26 20:11
用正则?

我之前试过用正则,太菜了写不出来。。因为内容跨行处理不好失败了

Twilight6 发表于 2020-5-26 21:08:02

本帖最后由 Twilight6 于 2020-5-26 21:09 编辑

菜鸟江湖 发表于 2020-5-26 21:05
我之前试过用正则,太菜了写不出来。。因为内容跨行处理不好失败了

看不懂你需求,你代码还带替换什么,需求都没写需要替换吧?

菜鸟江湖 发表于 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))

菜鸟江湖 发表于 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)

Twilight6 发表于 2020-5-28 17:07:23

人在家中睡,最佳天上来???{:10_297:}我喜欢,再来一打
页: [1]
查看完整版本: 循环读取文本指定内容进行替换并写入新文本