[英]How to turn one list element in two?
可以说我有一个像这样的列表:
bla = ['3,00 € 3,50 €\r\n', '3,00 €\r\n', '6,50 €\t5,50 €\r\n']
每次我在一个项目中有两个价格时,我都想将该项目变成两个项目。 所以看起来像这样:
['3,00 €', '3,50 €', '3,00 €', '6,50 €', '5,50 €']
使用正则表达式提取与<digits>,<digits> €
模式匹配的所有价格<digits>,<digits> €
并将结果列表展平:
import re
l = [item for s in [re.findall("[0-9]+,[0-9]+\s?€", x) for x in bla] for item in s]
编辑:
甚至更短,将您的列表连接到单个字符串,然后提取与所述模式匹配的所有字符串:
l = re.findall("[0-9]+,[0-9]+\s?€", " ".join(bla))
不使用正则表达式:根据欧元符号拆分并重新格式化,在此过程中将列表弄平,并去除所有空白:
bla = ['3,00 € 3,50 €\r\n', '3,00 €\r\n', '6,50 €\t5,50 €\r\n']
result = ["{} {}".format(x.strip(),"€") for item in bla for x in item.split("€") if x.strip()]
print(result)
结果:
['3,00 €', '3,50 €', '3,00 €', '6,50 €', '5,50 €']
这是另一种无需正则表达式的方式:
from itertools import chain
bla = ['3,00 € 3,50 €\v\n', '3,00 €\v\n', '6,50 €\t5,50 €\v\n']
result = [r for r in chain.from_iterable(((v+' €' for v in (y.strip()
for y in s.split('€') if y.strip()))
for s in bla))]
print(result)
输出:
['3,00 €', '3,50 €', '3,00 €', '6,50 €', '5,50 €']
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.