搜索包含数字python的字符串

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (38)

所以我有以下代码:

cus_str = "show configuration " #intiate router command string variable

with open(var) as config_file: #open file
    for line in config_file: #line by line reading of file
        if '"xe-" + #anynumber + "/" #anynumber + "/" + #anynumber' in line:
            line = line.replace('\n' , '').replace('"' , '').replace(']' , '')     #removes all extra characters
            i = "| except " + (line.split("cust ", 1)[1]) + " " #split the line and save last index (cust name)
        cus_str+=i #append to string
config_file.close()

这一行:如果'“xe-”+ #anynumber +“/”#anynumber +“/”+ #anynumber'在行:是我在语法方面苦苦挣扎。

我想查看文件中的一行是否包含以下字符串:“xe- number / number / number ”(例如:“xe-6/1/10”)。它将始终具有此格式,但数字将会更改。我会用什么样的语法来最有效地完成这项工作。

谢谢!

提问于
用户回答回答于

您可以使用正则表达式。正则表达式允许您指定文本模式(尽管并非所有模式都可以表示为正则表达式)。然后我们可以compile将该表达式转换为Pattern对象,并将该对象search用于模式的字符串。

import re

pattern = re.compile(r'"xe-\d+/\d+/\d+"')  # \d+ is "one or more digits".  
                                           # Everything else is literal

with open(var) as config_file:
    for line in config_file:
        if pattern.search(line):  # will return a Match object if found, else None
            ...
用户回答回答于

您可以使用一些简单的程序测试正则表达式,例如https://pythex.org/等在线工具,然后制作您的程序,一个小样本指向正确的方向:

import re

config_file = ["xe-6/1/10", "xf-5/5/542", "xe-4/53/32" ]
rex = re.compile(r'xe-[\d]+/[\d]+/[\d]+')
for line in config_file: #line by line reading of file
    if rex.search(line):
      print(line)

xe-6/1/10
xe-4/53/32

扫码关注云+社区

领取腾讯云代金券