如何在不创建子列表的情况下拆分python列表元素

时间:2016-05-09 16:48:00

标签: python

我正在尝试从日志文件中的一行文本中提取一些信息,该行有一些奇怪的分隔符,我可以使用split / replace / join等来解决这些问题。

当我尝试将第二个时间元素拆分为“ - ”并将其添加回列表时,问题就出现了,我最终得到了一个子列表 - 这不是我想要的。

line='2016-05-06T12:00:00.128189+01:00 mac-68c90b45b51e debug: 03959725-10:59:57.250[51222]*** NEW STATUS [3896374] : id=15 object=1 row=00408280 speed=0 crit=2 cell=130 intracell=512'

line1=(" ".join(line.split()).replace('[', '.').replace(']', ' ').strip().split())

结果;

['2016-05-06T12:00:00.128189+01:00', 'mac-68c90b45b51e', 'debug:', 03959725-10:59:57.250.51222', '***', 'NEW', 'STATUS', '.3896374', ':', 'id=15', 'object=1', 'row=00408280', 'speed=0', 'crit=2', 'cell=130', 'intracell=512']

当我尝试将<03959725-10:59:57.250.51222'拆分为

line1[3]=line1[3].replace('-', ' ').split()

我最终得到了;

['2016-05-06T12:00:00.128189+01:00', 'mac-68c90b45b51e', 'debug:', ['03959725', '10:59:57.250.51222'], '***', 'NEW', 'STATUS', '.3896374', ':', 'id=15', 'object=1', 'row=00408280', 'speed=0', 'crit=2', 'cell=130', 'intracell=512']

我想要的是什么;

    ['2016-05-06T12:00:00.128189+01:00', 'mac-68c90b45b51e', 'debug:', '03959725', '10:59:57.250.51222', '***', 'NEW', 'STATUS', '.3896374', ':', 'id=15', 'object=1', 'row=00408280', 'speed=0', 'crit=2', 'cell=130', 'intracell=512']

关于如何整理我的方式的任何想法?

3 个答案:

答案 0 :(得分:3)

您可以使用切片分配:

line1[3:4]=line1[3].replace('-', ' ').split()

它将用给定的序列替换切片​​:

>>> l = [1, 2, 3, 4, 5]
>>> l[3:4] = ['new', 'items']
>>> l
[1, 2, 3, 'new', 'items', 5]

答案 1 :(得分:1)

如果你有Python3.5,还有这种有趣的方式:

>>> a = [0, 1, 2, 'hello world whats up?', 4, 5]
>>> n = 3
>>> [*a[:n], *a[n].split(), *a[n+1:]]
[0, 1, 2, 'hello', 'world', 'whats', 'up?', 4, 5]

答案 2 :(得分:0)

像这样重建列表:

line1 = line1[0:3] + line1[3].replace('-', ' ').split() + line1[4:]