python字符串的常用操作方法小結(jié)
本文實(shí)例為大家分享了python字符串的操作方法,供大家參考,具體內(nèi)容如下
1.去除空格
str.strip():刪除字符串兩邊的指定字符,括號(hào)的寫入指定字符,默認(rèn)為空格
>>> a=' hello ' >>> b=a.strip() >>> print(b) hello
str.lstrip():刪除字符串左邊的指定字符,括號(hào)的寫入指定字符,默認(rèn)為空格
>>> a=' hello ' >>> b=a.lstrip() >>> print(b) hello #右邊空格可能看的不是很明顯
str.rstrip():刪除字符串右邊指定字符,默認(rèn)為空格
>>> a=' hello ' >>> b=a.rstrip() >>> print(b) hello
2.復(fù)制字符串
>>> a='hello world' >>> b=a >>> print(a,b) hello world hello world
3.連接字符串
+:連接2個(gè)字符串 >>> a='hello ' >>> b='world' >>> print(a+b) hello world 注:此方法又稱為 "萬惡的加號(hào)",因?yàn)槭褂眉犹?hào)連接2個(gè)字符串會(huì)調(diào)用靜態(tài)函數(shù)string_concat(register PyStringObject *a ,register PyObject * b),在這個(gè)函數(shù)中會(huì)開辟一塊大小是a+b的內(nèi)存的和的存儲(chǔ)單元,然后將a,b字符串拷貝進(jìn)去。如果是n個(gè)字符串相連 那么會(huì)開辟n-1次內(nèi)存,是非常耗費(fèi)資源的。 str.join:連接2個(gè)字符串,可指定連接符號(hào)(關(guān)于join,讀者可以自己去查看一些相關(guān)資料) >>> a='hello ' >>> b='####' >>> a.join(b) '#hello #hello #hello #'
4.查找字符串
#str.index 和str.find 功能相同,區(qū)別在于find()查找失敗會(huì)返回-1,不會(huì)影響程序運(yùn)行。一般用find!=-1或者find>-1來作為判斷條件。 str.index:檢測(cè)字符串中是否包含子字符串str,可指定范圍 a='hello world' >>> a.index('l') 2 >>> a.index('x') Traceback (most recent call last): File "<pyshell#40>", line 1, in <module> a.index('x') ValueError: substring not found str.find:檢測(cè)字符串中是否包含子字符串str,可指定范圍 >>> a='hello world' >>> a.find('l') 2 >>> a.find('x') -1
5.比較字符串
str.cmp:比較兩個(gè)對(duì)象,并根據(jù)結(jié)果返回一個(gè)整數(shù)。X< Y,返回值是負(fù)數(shù) ,X>Y 返回的值為正數(shù)。
#python3已經(jīng)沒有該方法,官方文檔是這么寫的:
The cmp() function should be treated as gone, and the __cmp__() special method is no longer supported. Use __lt__() for sorting, __eq__() with __hash__(), and other rich comparisons as needed. (If you really need the cmp() functionality, you could use the expression (a > b) - (a < b) as the equivalent for cmp(a, b).)
大意就是cmp()函數(shù)已經(jīng)“離開”了,如果你真的需要cmp()函數(shù),你可以用表達(dá)式(a > b) - (a < b)代替cmp(a,b)
>>> a=100 >>> b=80 >>> cmp(a,b) 1
6.是否包含指定字符串
in |not in >>> a='hello world' >>> 'hello' in a True >>> '123' not in a True
7.字符串長(zhǎng)度
str.len >>> a='hello world' >>> print(len(a)) 11
8.字符串中字母大小寫轉(zhuǎn)換
S.lower() #轉(zhuǎn)換為小寫 >>> a='Hello World' >>> print(a.lower()) hello world S.upper() #轉(zhuǎn)換為大寫 >>> a='Hello World' >>> print(a.upper()) HELLO WORLD S.swapcase() #大小寫互換 >>> a='Hello World' >>> print(a.swapcase()) hELLO wORLD S.capitalize() #首字母大寫 >>> a='Hello World' >>> print(a.capitalize()) Hello world
9.將字符串放入中心位置可指定長(zhǎng)度以及位置兩邊字符
str.center() >>> a='hello world' >>> print(a.center(40,'*')) **************hello world***************
10.字符串統(tǒng)計(jì)
>>> a='hello world' >>> print(a.count('l')) 3
11.字符串的測(cè)試、判斷函數(shù),這一類函數(shù)在string模塊中沒有,這些函數(shù)返回的都是bool值
S.startswith(prefix[,start[,end]]) #是否以prefix開頭 S.endswith(suffix[,start[,end]]) #以suffix結(jié)尾 S.isalnum() #是否全是字母和數(shù)字,并至少有一個(gè)字符 S.isalpha() #是否全是字母,并至少有一個(gè)字符 S.isdigit() #是否全是數(shù)字,并至少有一個(gè)字符 S.isspace() #是否全是空白字符,并至少有一個(gè)字符 S.islower() #S中的字母是否全是小寫 S.isupper() #S中的字母是否便是大寫 S.istitle() #S是否是首字母大寫的
12.字符串切片
str = '0123456789′ print str[0:3] #截取第一位到第三位的字符 print str[:] #截取字符串的全部字符 print str[6:] #截取第七個(gè)字符到結(jié)尾 print str[:-3] #截取從頭開始到倒數(shù)第三個(gè)字符之前 print str[2] #截取第三個(gè)字符 print str[-1] #截取倒數(shù)第一個(gè)字符 print str[::-1] #創(chuàng)造一個(gè)與原字符串順序相反的字符串 print str[-3:-1] #截取倒數(shù)第三位與倒數(shù)第一位之前的字符 print str[-3:] #截取倒數(shù)第三位到結(jié)尾 print str[:-5:-3] #逆序截取,截取倒數(shù)第五位數(shù)與倒數(shù)第三位數(shù)之間
這里需要強(qiáng)調(diào)的是,字符串對(duì)象是不可改變的,也就是說在python創(chuàng)建一個(gè)字符串后,你不能把這個(gè)字符中的某一部分改變。任何上面的函數(shù)改變了字符串后,都會(huì)返回一個(gè)新的字符串,原字串并沒有變。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Python Selenium自動(dòng)化獲取頁面信息的方法
這篇文章主要介紹了Python Selenium自動(dòng)化獲取頁面信息的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08

python+OpenCV實(shí)現(xiàn)車牌號(hào)碼識(shí)別

為Python的web框架編寫MVC配置來使其運(yùn)行的教程

如何利用python創(chuàng)建、讀取和修改CSV數(shù)據(jù)文件

詳解Python基礎(chǔ)random模塊隨機(jī)數(shù)的生成

python3.7+anaconda 安裝opencv和dlib的問題及解決方法