有没有一种pythonic方式将元素插入字符串中的每个第二个元素?
我有一个字符串:“ aabbccdd”,我希望最终结果是“ aa-bb-cc-dd”。
我不确定该怎么做。
假设字符串的长度始终是偶数,
>>> s = '12345678' >>> t = iter(s) >>> '-'.join(a+b for a,b in zip(t, t)) '12-34-56-78'
该t也可以消除
t
>>> '-'.join(a+b for a,b in zip(s[::2], s[1::2])) '12-34-56-78'
算法是将字符串分组为对,然后将其与-字符连接在一起。
-
代码是这样写的。首先,它分为奇数位和偶数位。
>>> s[::2], s[1::2] ('1357', '2468')
然后使用该zip函数将它们组合成一个可迭代的元组。
zip
>>> list( zip(s[::2], s[1::2]) ) [('1', '2'), ('3', '4'), ('5', '6'), ('7', '8')]
但是元组不是我们想要的。这应该是一个字符串列表。这是列表理解的目的
>>> [a+b for a,b in zip(s[::2], s[1::2])] ['12', '34', '56', '78']
最后,我们使用str.join()合并列表。
str.join()
第一部分代码是相同的想法,但是如果字符串很长,则会消耗更少的内存。