您好,登錄后才能下訂單哦!
這篇文章主要介紹“Python如何提高查找字串的運(yùn)行速度”,在日常操作中,相信很多人在Python如何提高查找字串的運(yùn)行速度問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Python如何提高查找字串的運(yùn)行速度”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
如果讓你寫一個有關(guān)Python字串查找的程序檢查字符串s2中是不是包含有s1。也許你會很直觀的寫下下面的代碼:
#determine whether s1 is a substring of s2 def isSubstring1(s1,s2): tag = False lenlen1 = len(s1) lenlen2 = len(s2) for i in range(0,len2): if s2[i] == s1[0]: for j in range(0,len1): if s2[i]==s1[j]: tag = True return tag
可是這是Python,我們可以利用字符串自帶的find()方法,于是可以這樣:
def isSubstring2(s1,s2): tag = False if s2.find(s1) != -1: tag = True return tag
悲情的事就在于此,原來Python中的關(guān)鍵字"in”不僅可以用于列表、元祖等數(shù)據(jù)類型,還可以用于字符串。所以,這里只需要直接一行代碼搞定:
def isSubstring3(s1,s2): return s1 in s2后知后覺了,慚愧;-)
類似的,假設(shè)要在字符串中,查找多個子串是否存在,并打印出這些串和***出現(xiàn)的位置:
def findSubstrings(substrings,destString):
res = map(lambda x:str([destString.index(x),x]),filter
(lambda x:x in destString,substrings))if res:
return ', '.join(list(res)) ;-) very cool~UPDATE:
如果你不習(xí)慣***面這種看起來很復(fù)雜的語法也沒關(guān)系,可以使用列表解析,更加簡潔:
def findSubstrings(substrings,destString): return ', '.join
([str([destString.index(x),x]) for x in substrings if x in destString])
到此,關(guān)于“Python如何提高查找字串的運(yùn)行速度”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。