五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動(dòng)態(tài)

Python 字符串操作詳情

發(fā)布日期:2021-12-16 22:49 | 文章來(lái)源:源碼之家

1、字符串的定義

所謂字符串,就是由0個(gè)或者多個(gè)字符組成的有限序列。

Python程序中,如果我們把單個(gè)或多個(gè)字符用單引號(hào)''或者雙引號(hào)""包裹起來(lái),就可以表示一個(gè)字符串,也可以用三個(gè)單引號(hào)或者雙引號(hào)進(jìn)行折行。字符串的字符可以是特殊符號(hào)、英文字母、中文字符、日文的平假名或片假名、希臘字母、Emoji字符等等。

如下代碼展示了Python中的字符串:

text1 = "這是用雙引號(hào)包裹的字符串"
text2 = '這是用單引號(hào)包裹的字符串'
text3 = """
這一個(gè)是那個(gè)三個(gè)引號(hào)包裹的字符串
可以保留原來(lái)的格式
"""
print(text1)
print(text2)
print(text3)

代碼運(yùn)行結(jié)果如下:

這是用雙引號(hào)包裹的字符串
這是用單引號(hào)包裹的字符串

這一個(gè)是那個(gè)三個(gè)引號(hào)包裹的字符串
可以保留原來(lái)的格式

2、轉(zhuǎn)義字符串和原始字符串

Python中使用反斜杠“”來(lái)表示轉(zhuǎn)義,也就是說(shuō)后面的內(nèi)容就不會(huì)是原始的內(nèi)容了,例如\n則表示換行,而不再表示和字符n了;所以如果字符串本身包含了 '、"、這些特殊的字符,必須要通過(guò)``進(jìn)行轉(zhuǎn)義處理。

示例代碼如下所示:

text1 = "\'Hello world\'"  # 輸出被單引號(hào)包裹的Hello world
text2 = '\\Hello world\\'  # 輸出被兩個(gè)反斜線包裹的Hello world

print(text1)
print(text2)

下面展示了python中的一些轉(zhuǎn)義字符:

原始字符串是Python中一類比較特殊的字符串,以大寫字母R或者小寫字母r開(kāi)始。在原始字符串中,字符“\” 不再表示轉(zhuǎn)義字符的含義。

示例代碼如下所示:

text1 = "古之立大事者,\n不惟有超世之才,\n亦必有堅(jiān)忍不拔之志"
text2 = r"古之立大事者,\n不惟有超世之才,\n亦必有堅(jiān)忍不拔之志"
print(text1)
print(text2)

運(yùn)行代碼如下所示:

古之立大事者,
不惟有超世之才,
亦必有堅(jiān)忍不拔之志
古之立大事者,\n不惟有超世之才,\n亦必有堅(jiān)忍不拔之志

3、字符串的運(yùn)算

Python為字符串類型提供了非常多的運(yùn)算符

3.1 拼接運(yùn)算符

使用+運(yùn)算符來(lái)實(shí)現(xiàn)字符串的拼接,使用*運(yùn)算符來(lái)重復(fù)一個(gè)字符串的內(nèi)容

text1 = "Hello,world"
text2 = "!"
print(text1 + text2)  # Hello,world!
print(text2 * 10)  # !!!!!!!!!!

用*實(shí)現(xiàn)字符串的重復(fù)是很重要,比如要打印一個(gè)分隔線如果寫成---------------會(huì)很麻煩的,但是如果用- * 20就很簡(jiǎn)單了

3.2 成員運(yùn)算

Python中可以用in和not in判斷一個(gè)字符串中是否存在另外一個(gè)字符或字符串,innot in運(yùn)算通常稱為成員運(yùn)算,會(huì)產(chǎn)生布爾值TrueFalse

text1 = "Hello,world"
text2 = "一碗周"
print("llo" in text1)  # True
print("周" not in text2)  # False
print("粥" not in text2)  # True

4、獲取字符串長(zhǎng)度

通過(guò)內(nèi)置函數(shù)len()來(lái)獲取字符的長(zhǎng)度

text1 = "Hello,world"
text2 = "一碗周"
print(len(text1))  # 11
print(len(text2))  # 3

5、索引和切片

如果在字符串中引用某個(gè)字符,可以對(duì)字符從進(jìn)行索引運(yùn)算(注:Python的索引值是從0開(kāi)始的),運(yùn)算符是[n],其中n是一個(gè)整數(shù),假設(shè)字符串的長(zhǎng)度為N,那么n可以是從0到N-1的整數(shù),其中0是字符串中第一個(gè)字符的索引,而N-1是字符串中最后一個(gè)字符的索引,通常稱之為正向索引;在Python中,字符串的索引也可以是從-1到-N的整數(shù),其中-1是最后一個(gè)字符的索引,而-N則是第一個(gè)字符的索引,通常稱之為負(fù)向索引。

值得注意的是,因?yàn)樽址遣豢勺冾愋停圆荒芡ㄟ^(guò)索引運(yùn)算修改字符串中的字符。

text1 = "Hello,world"
text2 = "一碗周"
N1 = len(text1)
N2 = len(text2)
# 獲取第一個(gè)字符
print(text1[0], text1[-N1])  # H H
print(text2[0], text2[-N2])  # 一 一
# 獲取最后一個(gè)字符
print(text1[N1 - 1], text1[-1])  # d d
print(text2[N2 - 1], text2[-1])  # 周 周
# 獲取索引為2和-2的字符
print(text1[2], text1[-2])  # l l
print(text2[2], text2[-2])  # 周 碗

注意:如果索引越界(即索引值不在索引范圍內(nèi))會(huì)引起錯(cuò)誤,例如

print(text2[222])

錯(cuò)誤信息如下:

IndexError: string index out of range # (字符串索引超出范圍)

如果要取出多個(gè)字符,要對(duì)字符串進(jìn)行切片,運(yùn)算符是[i:j:k] ,其中i是開(kāi)始索引,索引對(duì)應(yīng)的字符可以不能取到N-1或者-1;j是結(jié)束索引,索引對(duì)應(yīng)的字符不能取到0或者-N;k是步長(zhǎng),默認(rèn)值為1,表示從前向后獲取相鄰字符的連續(xù)切片(可以省略),如果k的值為正數(shù),即為正向索引;如果k的值為負(fù)數(shù),即為負(fù)向索引。

s = '123456789abcdef,一碗周'
# i=3, j=6, k=1的正向切片操作
print(s[3:6]) # 456
# i=-17, j=-14, k=1的正向切片操作
print(s[-17:-14])  # 456
# i=16, j=默認(rèn), k=1的正向切片操作
print(s[16:])  # 一碗周
# i=-4, j=默認(rèn), k=1的正向切片操作
print(s[-3:]) # 一碗周
# i=8, j=默認(rèn), k=2的正向切片操作
print(s[8::2])# 9bdf一周
# i=-12, j=默認(rèn), k=2的正向切片操作
print(s[-12::2])  # 8ace,碗
# i=默認(rèn), j=默認(rèn), k=2的正向切片操作
print(s[::2]) # 13579bdf一周
# i=默認(rèn), j=默認(rèn), k=1的正向切片
print(s[:])# 123456789abcdef,一碗周
# i=1, j=-1, k=2的正向切片操作
print(s[1:-1:2]) # 2468ace,碗
print("-"*20)
# i=7, j=1, k=-1的負(fù)向切片操作
print(s[7:1:-1]) # 876543
# i=-13, j=-19, k=-1的負(fù)向切片操作
print(s[-13:-19:-1])  # 876543
# i=8, j=默認(rèn), k=-1的負(fù)向切片操作
print(s[8::-1])  # 987654321
# i=默認(rèn), j=1, k=-1的負(fù)向切片操作
print(s[:15:-1])  # 周碗一
# i=默認(rèn), j=默認(rèn), k=-1的負(fù)向切片
print(s[::-1])# 周碗一,fedcba987654321
# i=默認(rèn), j=默認(rèn), k=-2的負(fù)向切片
print(s[::-2])# 周一fdb97531

i的默認(rèn)值為最開(kāi)始的那個(gè)數(shù),j的默認(rèn)值為結(jié)束的那個(gè)數(shù)(包括本身)

值得注意的是,返回的字符串是包括i不包括j的。

6、字符串的方法

Python中使用字符串的類型自帶的方法對(duì)字符串進(jìn)行處理和操作,對(duì)于一個(gè)字符串類型的變量,使用變量名.方法名()的方式來(lái)調(diào)用它的方法。所謂方法其實(shí)就是跟某個(gè)類型的變量綁定的函數(shù)。

6.1 轉(zhuǎn)換大小寫

s1 = 'hello, world!'
# 使用capitalize方法獲得字符串首字母大寫后的字符串
print(s1.capitalize())# Hello, world!
# 使用title方法獲得字符串每個(gè)單詞首字母大寫后的字符串
print(s1.title())  # Hello, World!
# 使用upper方法獲得字符串大寫后的字符串
print(s1.upper())  # HELLO, WORLD!
s2 = 'GOODBYE'
# 使用lower方法獲得字符串小寫后的字符串
print(s2.lower())  # goodbye

6.2 查找操作

如果想在一個(gè)字符串中從前向后查找有沒(méi)有另外一個(gè)字符串,可以使用字符串的findindex方法。

s = 'hello, world!'

# find方法從字符串中查找另一個(gè)字符串所在的位置
# 找到了返回字符串中另一個(gè)字符串首字符的索引
print(s.find('or'))  # 8
# 找不到返回-1
print(s.find('shit'))# -1
# index方法與find方法類似
# 找到了返回字符串中另一個(gè)字符串首字符的索引
print(s.index('or')) # 8
# 找不到引發(fā)異常
print(s.index('shit'))  # ValueError: substring not found

在使用findindex方法時(shí)還可以通過(guò)方法的參數(shù)來(lái)指定查找的范圍,就是不必從索引0的位置開(kāi)始。``find和index方法還有逆向查找(從后向前查找)的版本,分別是rfindrindex`

s = 'hello good world!'
# 從前向后查找字符o出現(xiàn)的位置(相當(dāng)于第一次出現(xiàn))
print(s.find('o')) # 4
# 從索引為5的位置開(kāi)始查找字符o出現(xiàn)的位置
print(s.find('o', 5)) # 7
# 從后向前查找字符o出現(xiàn)的位置(相當(dāng)于最后一次出現(xiàn))
print(s.rfind('o'))# 12

6.3性質(zhì)判斷

可以通過(guò)字符串的startswithendswith來(lái)判斷字符串是否以某個(gè)字符串開(kāi)頭和結(jié)尾;還可以用is開(kāi)頭的方法判斷字符串的特征,這些方法都返回布爾值。

s1 = 'hello, world!'
# startwith方法檢查字符串是否以指定的字符串開(kāi)頭返回布爾值
print(s1.startswith('He')) # False
print(s1.startswith('hel'))# True
# endswith方法檢查字符串是否以指定的字符串結(jié)尾返回布爾值
print(s1.endswith('!')) # True
s2 = 'abc123456'
# isdigit方法檢查字符串是否由數(shù)字構(gòu)成返回布爾值
print(s2.isdigit()) # False
# isalpha方法檢查字符串是否以字母構(gòu)成返回布爾值
print(s2.isalpha()) # False
# isalnum方法檢查字符串是否以數(shù)字和字母構(gòu)成返回布爾值
print(s2.isalnum()) # True

6.4格式化字符串

在Python中,字符串類型可以通過(guò)center、ljust、rjust方法做居中、左對(duì)齊和右對(duì)齊的處理。

s = 'hello, world'
# center方法以寬度20將字符串居中并在兩側(cè)填充*
print(s.center(20, '*'))  # ****hello, world****
# rjust方法以寬度20將字符串右對(duì)齊并在左側(cè)填充空格
print(s.rjust(20))  #hello, world
# ljust方法以寬度20將字符串左對(duì)齊并在右側(cè)填充~
print(s.ljust(20, '~'))# hello, world~~~~~~~~

Python2.6 開(kāi)始,新增了一種格式化字符串的函數(shù) str.format() ,它增強(qiáng)了字符串格式化的功能。

基本語(yǔ)法是通過(guò) {}: 來(lái)代替以前的 % 。

a = 111
b = 222
print('{0} + {1} = {2}'.format(a, b, a + b)) # 111 + 222 = 333
c = "hello"
d = "world"
# 不設(shè)置指定位置,按默認(rèn)順序
print("{} {}".format(c, d))  # hello world
print("{0} {1}".format(c, d))# hello world
print("{1} {0}".format(d, c))# hello world
print("{1} {0} {1}".format(c, d))  # world hello world

Python 3.6開(kāi)始,格式化字符串還有更為簡(jiǎn)潔的書寫方式,就是在字符串前加上f來(lái)格式化字符串,在這種以f打頭的字符串中,{變量名}是一個(gè)占位符,會(huì)被變量對(duì)應(yīng)的值將其替換掉。

a = 111
b = 222
print(f"{a} +  = {a + b}") # 111 + 222 = 333
c = "hello"
d = "world"
print(f"{c} 0znxipo")  # hello world

對(duì)數(shù)字格式化的多種操作

分別是居中、左對(duì)齊、右對(duì)齊,后面帶寬度,:號(hào)后面帶填充的字符,只能是一個(gè)字符,不指定則默認(rèn)是用空格填充。

+表示在正數(shù)前顯示+ ,負(fù)數(shù)前顯示 - ; (空格)表示在正數(shù)前加空格 b、d、o、x 分別是二進(jìn)制、十進(jìn)制、八進(jìn)制、十六進(jìn)制。

7、修剪操作

strip() 方法用于移除原字符串修剪掉左右指定的字符(默認(rèn)為空格或換行符)或字符序列。這個(gè)方法非常有實(shí)用價(jià)值,通常用來(lái)將用戶輸入中因?yàn)椴恍⌒逆I入的頭尾空格去掉,strip方法還有lstrip(即left strip)和rstrip(即right strip)兩個(gè)版本。

s = '一碗周  \t\n'
# strip方法獲得字符串修剪左右兩側(cè)空格之后的字符串
print(s.strip()) # 一碗周
s1 = "!!!一碗周!!!"
print(s1.lstrip("!"))  # 一碗周!!!
print(s1.rstrip("!"))  # !!!一碗周

到此這篇關(guān)于Python 字符串操作詳情的文章就介紹到這了,更多相關(guān)Python 字符串操作內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開(kāi)通

自選配置、實(shí)時(shí)開(kāi)通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問(wèn)服務(wù)

1對(duì)1客戶咨詢顧問(wèn)

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部