假设字符串的长度始终是偶数,
>>> s = '12345678'>>> t = iter(s)>>> '-'.join(a+b for a,b in zip(t, t))'12-34-56-78'
该
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函数将它们组合成一个可迭代的元组。
>>> 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()合并列表。
>>> '-'.join(a+b for a,b in zip(s[::2], s[1::2]))'12-34-56-78'
第一部分代码是相同的想法,但是如果字符串很长,则会消耗更少的内存。



