1、你需要通過指定的文本模式去檢查字符串的開頭或者結(jié)尾,比如文件名后綴,URL Scheme 等等。檢 查 字 符 串 開 頭 或 結(jié) 尾 的 一 個(gè) 簡 單 方 法 是 使 用str.startswith() 或 者 是str.endswith()方法。比如:
>>> filename = 'spam.txt'>>> filename.endswith('.txt')True>>> filename.startswith('file:')False>>> url = 'http://www.python.org'>>> url.startswith('http:')True>>> 2、如果你想檢查多種匹配可能,只需要將所有的匹配項(xiàng)放入到一個(gè)元組中去,然后傳給 startswith()或者 endswith() 方法:
>>> import os>>> filenames = os.listdir('.')>>> filenames[ 'Makefile', 'foo.c', 'bar.py', 'spam.c', 'spam.h' ]>>> [name for name in filenames if name.endswith(('.c', '.h')) ]['foo.c', 'spam.c', 'spam.h'>>> any(name.endswith('.py') for name in filenames)True>>> #示例2from urllib.request import urlopendef read_data(name): if name.startswith(('http:', 'https:', 'ftp:')): return urlopen(name).read() else: with open(name) as f: return f.read() 奇怪的是,這個(gè)方法中必須要輸入一個(gè)元組作為參數(shù)。如果你恰巧有一個(gè)list 或者 set類型的選擇項(xiàng),要確保傳遞參數(shù)前先調(diào)用 tuple()將其轉(zhuǎn)換為元組類型。比如:
>>> choices = ['http:', 'ftp:']>>> url = 'http://www.python.org'>>> url.startswith(choices)Traceback (most recent call last):File "<stdin>", line 1, in <module>TypeError: startswith first arg must be str or a tuple of str, not list>>> url.startswith(tuple(choices))True>>>
3、startswith() 和 endswith() 方法提供了一個(gè)非常方便的方式去做字符串開頭和結(jié)尾的檢查。類似的操作也可以使用切片來實(shí)現(xiàn),但是代碼看起來沒有那么優(yōu)雅。比如:
>>> filename = 'spam.txt'>>> filename[-4:] == '.txt'True>>> url = 'http://www.python.org'>>> url[:5] == 'http:' or url[:6] == 'https:' or url[:4] == 'ftp:'True>>>
4、你可以能還想使用正則表達(dá)式去實(shí)現(xiàn),比如:
>>> import re>>> url = 'http://www.python.org'>>> re.match('http:jhttps:jftp:', url)<_sre.SRE_Match object at 0x101253098>>>>5、當(dāng)和其他操作比如普通數(shù)據(jù)聚合相結(jié)合的時(shí)候 startswith()和endswith() 方法是很不錯(cuò)的。比如,下面這個(gè)語句檢查某個(gè)文件夾中是否存在指定的文件類型:
if any(name.endswith(('.c', '.h')) for name in listdir(dirname)):...以上這篇對python 匹配字符串開頭和結(jié)尾的方法詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持武林站長站。
新聞熱點(diǎn)
疑難解答
圖片精選