在python中将行放在搜索值之上

时间:2011-11-14 01:36:26

标签: python regex sed multiline

我有一个文本文件,我想搜索特定的IP地址,文本文件的设置方式是主机名高于ip add。即

real HOSTNAME

address xx.xx.xx.xx

当我只获取要搜索的IP地址时,获取主机名的最佳/最简单的方法是什么?常用表达? python中是否有像sed一样的实用程序?感谢任何帮助

3 个答案:

答案 0 :(得分:3)

正则表达式可能是最简单的解决方案。

>>> textdata = '''
someline
another line
real HOSTNAME

address 127.0.0.1
post 1
post 2
'''
>>> re.findall('^(.*)$\n^.*$\naddress 127.0.0.1', textdata, re.MULTILINE)
['real HOSTNAME']

您也可以使用linecache module或只是使用f.readlines()将所有行读入列表。

答案 1 :(得分:2)

这可能不是最佳解决方案,但您可以使用deque来捕获目标线上方的n行:

from collections import deque
from itertools import takewhile

test = """
real others

address xxx.xxx.xxx

real local

address 127.0.0.1

real others

address xxx.xxx.xxx
""".split("\n")

pattern = "address 127.0.0.1"
print deque(takewhile(lambda x:x.strip()!=pattern, test), 2)[0]

将测试变量更改为file(“yourfilename”)以从文本文件中读取行。

答案 2 :(得分:2)

如果您知道主机名在ip之前有多少行,那么您可以枚举一个行列表,并从当前索引中减去必要的行数:

lines = open("someFile", "r").read().splitlines()
IP = "10.10.1.10"
hostname = None
for i, line in enumerate(lines):
    if IP in line:
        hostname = lines[i - 1]
        break

if hostname:
    # Do stuff