您好,登錄后才能下訂單哦!
這篇文章主要介紹“Python如何提高查找字串的運行速度”,在日常操作中,相信很多人在Python如何提高查找字串的運行速度問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Python如何提高查找字串的運行速度”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
如果讓你寫一個有關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中的關鍵字"in”不僅可以用于列表、元祖等數據類型,還可以用于字符串。所以,這里只需要直接一行代碼搞定:
def isSubstring3(s1,s2): return s1 in s2后知后覺了,慚愧;-)
類似的,假設要在字符串中,查找多個子串是否存在,并打印出這些串和***出現的位置:
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:
如果你不習慣***面這種看起來很復雜的語法也沒關系,可以使用列表解析,更加簡潔:
def findSubstrings(substrings,destString): return ', '.join
([str([destString.index(x),x]) for x in substrings if x in destString])
到此,關于“Python如何提高查找字串的運行速度”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。