前言
最近工作中遇到一個問題,需求是碰到'122333<<<<'這種字符串,要將其連貫的部分取出,得出['1', '22', '333', '<<<<']這樣的列表,能想到的常規辦法,遍歷字符串,后一個與前一個逐個比較,這樣真的很麻煩!又想到了另外兩種方法,話不多說了,來一起看看詳細的示例代碼:
一、實際上可以借助itertools模塊的groupby()方法來處理:
import itertools Str = '122333<<<<' Lst = [] for key,group in itertools.groupby(s): Lst.append(list(group)) print map(lambda x: ''.join(x), Lst)
上面的處理,還是比較有技巧,也能得到想要的輸出結果
['1', '22', '333', '<<<<']
二、但更酷點,更技巧處理方式是用正則表達式來處理:
import re Str = '122333<<<<' Lst = [] Pat = re.compile(r'((.)/2*)') Rst = [x[0] for x in re.findall(Pat, Str)] print Rst
備注:
1. (.) # .匹配任意字符;(.)做分組,方便后面反向引用
2. /2* # /2對里面括號的反向引用;*代表是0個到多個;
3. ((.)/2*) # 連起來就是任意一個或多個字符組成的分組;
4. (.)/1* # 這種方式則可以取出唯一的值['1', '2', '3', '<'];同樣非常方便
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答