使用正则表达式将多行脚本输出转换为字典

时间:2015-06-21 10:40:12

标签: python regex dictionary

我得到了以下脚本输出:

***************************************************
[g4u2680c]: searching for domains
---------------------------------------------------
host =   g4u2680c.houston.example.com
         ipaddr = [16.208.16.72]
         VLAN   = [352]
         Gateway= [16.208.16.1]
         Subnet = [255.255.248.0]
         Subnet = [255.255.248.0]
         Cluster= [g4u2679c g4u2680c g9u1484c g9u1485c]

host =   g4u2680c.houston.example.com
         ipaddr = [16.208.16.72]
         VLAN   = [352]
         Gateway= [16.208.16.1]
         Subnet = [255.255.248.0]
         Subnet = [255.255.248.0]
         Cluster= [g4u2679c g4u2680c g9u1484c g9u1485c]

* script completed Mon Jun 15 06:13:14 UTC 2015 **
* sleeping 30 to avoid DOS on dns via a loop **

我需要将2个主机列表提取到字典中,不带括号。

这是我的代码:

#!/bin/env python

import re

text="""*************************************************** 
[g4u2680c]: searching for domains
---------------------------------------------------
host =   g4u2680c.houston.example.com
         ipaddr = [16.208.16.72]
         VLAN   = [352]
         Gateway= [16.208.16.1]
         Subnet = [255.255.248.0]
         Subnet = [255.255.248.0]
         Cluster= [g4u2679c g4u2680c g9u1484c g9u1485c]

host =   g4u2680c.houston.example.com
         ipaddr = [16.208.16.72]
         VLAN   = [352]
         Gateway= [16.208.16.1]
         Subnet = [255.255.248.0]
         Subnet = [255.255.248.0]
         Cluster= [g4u2679c g4u2680c g9u1484c g9u1485c]

* script completed Mon Jun 15 06:13:14 UTC 2015 **
* sleeping 30 to avoid DOS on dns via a loop **
***************************************************
"""

seq = re.compile(r"host.+?\n\n",re.DOTALL)

a=seq.findall(text)

matches = re.findall(r'\w.+=.+', a[0])

matches = [m.split('=', 1) for m in matches]

matches = [ [m[0].strip().lower(), m[1].strip().lower()] for m in matches]

#should have function with regular expression to remove bracket here

d = dict(matches)

print d

到目前为止,第一位主持人得到了什么:

{'subnet': '[255.255.248.0]', 'vlan': '[352]', 'ipaddr': '[16.208.16.72]', 'cluster': '[g4u2679c g4u2680c g9u1484c g9u1485c]', 'host': 'g4u2680c.houston.example.com', 'gateway': '[16.208.16.1]'}

我需要帮助才能找到正则表达式来删除括号,因为字典中的值包含带括号和不带括号的数据。

或者,如果有更好更简单的方法将原始脚本输出转换为字典。

3 个答案:

答案 0 :(得分:1)

您只需使用re.findalldict

即可
>>> dict([(i,j.strip('[]')) for i,j in re.findall(r'(\w+)\s*=\s*(.+)',text)])
{'Subnet': '255.255.248.0', 'VLAN': '352', 'ipaddr': '16.208.16.72', 'Cluster': 'g4u2679c g4u2680c g9u1484c g9u1485c', 'host': 'g4u2680c.houston.example.com', 'Gateway': '16.208.16.1'}

关于括号,您可以通过str.strip方法删除它们。

答案 1 :(得分:1)

您可以使用: (\w+)\s*=\s*\[?([^\n\]]+)\]?

demo

import re
p = re.compile(ur'(\w+)\s*=\s*\[?([^\n\]]+)\]?', re.MULTILINE)
test_str = u"host =   g4u2680c.houston.example.com\n         ipaddr = [16.208.16.72]\n         VLAN   = [352]\n         Gateway= [16.208.16.1]\n         Subnet = [255.255.248.0]\n         Subnet = [255.255.248.0]\n         Cluster= [g4u2679c g4u2680c g9u1484c g9u1485c]\n\nhost =   g4u2680c.houston.example.com\n         ipaddr = [16.208.16.72]\n         VLAN   = [352]\n         Gateway= [16.208.16.1]\n         Subnet = [255.255.248.0]\n         Subnet = [255.255.248.0]\n         Cluster= [g4u2679c g4u2680c g9u1484c g9u1485c]\n"

re.findall(p, test_str)

答案 2 :(得分:0)

你可以尝试一下。

matches = [m.replace('[','').replace(']','').split('=', 1) for m in matches]