目的
把字符串逐字符或逐词反转过来,这个蛮有意思的。
方法
先看逐字符反转吧,第一种设置切片的步长为-1
代码如下:
revchars=astring[::-1]
in [65]: x=’abcd’
in [66]: x[::-1]
out[66]: ‘dcba’
第二种做法是采用reversed(),注意它返回的是一个迭代器,可以用于循环或传递给其它的“累加器”,不是一个已完成的字符串。
代码如下:
revchars=”.join(reversed(astring))
in [56]: y=reversed(x)
in [57]: y
out[57]:
in [58]: ”.join(y)
out[58]: ‘dcba’
接着来看逐词反转。
第一种做法,创建一个列表,将列表反转,用join方法合并
代码如下:
in [38]: s=’today is really a good day’
in [39]: rev=s.split()
in [40]: rev
out[40]: [‘today’, ‘is’, ‘really’, ‘a’, ‘good’, ‘day’]
in [41]: rev.reverse()
in [42]: rev
out[42]: [‘day’, ‘good’, ‘a’, ‘really’, ‘is’, ‘today’]
in [45]: ‘ ‘.join(rev)
out[45]: ‘day good a really is today’
也有一行解决的代码:
代码如下:
rev=’ ‘.join(s.split()[::-1])
第二种做法,可以不改变原先的空格,采用正则式来做:
代码如下:
in [46]: import re
in [47]: rev=re.split(r'(\s+)’,s)
in [48]: rev
out[48]: [‘today’, ‘ ‘, ‘is’, ‘ ‘, ‘really’, ‘ ‘, ‘a’, ‘ ‘, ‘good’, ‘ ‘, ‘day’]
in [49]: rev.reverse()
in [50]: rev
out[50]: [‘day’, ‘ ‘, ‘good’, ‘ ‘, ‘a’, ‘ ‘, ‘really’, ‘ ‘, ‘is’, ‘ ‘, ‘today’]
in [51]: rev=”.join(rev)
in [52]: rev
out[52]: ‘day good a really is today’
可以考虑采用reversed()来代替可读性较差的[::-1]
代码如下:
revwords=’ ‘.join(reversed(s.split()))
revwords=”.join(reversed(re.split(r'(\s+)’,s)))