1.字符串中的元素
1.阻止轉(zhuǎn)義
在字符串的最前面可以添加r/R來(lái)阻止字符串中的轉(zhuǎn)義字符轉(zhuǎn)義
str1 = r'how \are you\n fine'
print(str1)
str1 = R'\t你好嗎?'
print(str1)
2.
python中可以把字符串看成是一個(gè)序列(容器),容器中內(nèi)容是字符。
每一個(gè)字符可以稱為字符串中的元素
字符串是一個(gè)不可變的序列,有序(不可變指的是字符串中的每個(gè)字符奶是,以及每個(gè)字符的位置不可變)
3.獲取字符串中的單個(gè)字符
語(yǔ)法: 字符串[下標(biāo)] ---> 根據(jù)下標(biāo)獲取字符串中的字符
說(shuō)明:a.字符串:可以是字符串的變量,也可以是字符串值
b.[]:固定寫法
c.下標(biāo):0~字符串長(zhǎng)度-1; -1 ~ -長(zhǎng)度
注意:下標(biāo)是整數(shù);下標(biāo)不能越界
python中每個(gè)字符串中字符都會(huì)對(duì)應(yīng)一個(gè)下標(biāo)兜叨,下標(biāo)是根據(jù)字符在字符串中的位置,從前往后依次增加的(第一個(gè)值是0)
練習(xí):獲取'good good study\n day day up!'
注意:一個(gè)空格算一個(gè)字符, 一個(gè)轉(zhuǎn)義字符算一個(gè)字符衩侥,一個(gè)制表符也是算一個(gè)字符
4.獲取字符串中的部分字符(切片)
a.**語(yǔ)法:字符串[起始下標(biāo):結(jié)束下標(biāo)] --> 獲取字符串中從起始下標(biāo)開(kāi)始国旷,到結(jié)束下標(biāo)前的所有的字符默認(rèn)步長(zhǎng)為1
注意:起始下標(biāo)對(duì)應(yīng)的字符要在結(jié)束下標(biāo)對(duì)應(yīng)的字符的前面,否取不到值
b.語(yǔ)法:字符串[起始下標(biāo):結(jié)束下標(biāo):步長(zhǎng)] --> 從起始下標(biāo)開(kāi)始獲取茫死,每步長(zhǎng)獲取一個(gè)跪但,獲取到結(jié)束下標(biāo)前為止步長(zhǎng)為正: 從前往后取(起始下標(biāo)對(duì)應(yīng)的字符要在結(jié)束下標(biāo)對(duì)應(yīng)的字符的前面,否取不到值)
步長(zhǎng)為負(fù):從后往前取(起始下標(biāo)對(duì)應(yīng)的字符要在結(jié)束下標(biāo)對(duì)應(yīng)的字符的后面峦萎,否取不到值)
c.切片時(shí)下標(biāo)可以省略屡久,省略不同的下標(biāo)有不同的意義
省略起始下標(biāo): 字符串[:結(jié)束下標(biāo)] ----> 從開(kāi)頭開(kāi)始取 (注意:這兒開(kāi)頭可能是第一個(gè)字符也可能是最后一個(gè)字符)
省略結(jié)束下標(biāo): 字符[起始下標(biāo):] ---> 從開(kāi)始下標(biāo)取,取完為止
兩個(gè)下標(biāo)都拾啤: 字符[:] ----> 全部取完
注意:切片的時(shí)候下標(biāo)可以越界
2.字符串運(yùn)算符
python中的字符串支持+被环、*和比較運(yùn)算符
1. 字符串的+號(hào)運(yùn)算符
字符串1 + 字符串2 ----> 將字符串1和字符串2拼接在一起產(chǎn)生一個(gè)新的字符串
注意:+兩邊要么都是數(shù)字,要么都是字符串搓蚪,不能一樣一個(gè)
str1 = '玉樹(shù)臨風(fēng)美少年'
str2 = '攬鏡自顧夜不眠'
print(str1 + str2)
new_str = str1 + ' ' + str2 + '!'
print(new_str)
print(str1 + ',' + str2)
2. *
字符串1 * n ----> 字符串1重復(fù)n次蛤售,產(chǎn)生一個(gè)新的字符串
n必須是整數(shù)
str3 = '家有千金,行止由心!'
print(str3*3)
先算乘再算加
str4 = str1 + str3 * 2
print(str4)
3.比較運(yùn)算符
判斷相等
print('abc' == 'abc') # 判斷兩個(gè)字符串的值是否相等
print('abc' != 'ab')
字符串比較大小: 比較兩個(gè)字符串中從前往后每個(gè)字符的編碼值的大小,比較到兩個(gè)字符不相同為止
print('zabcdef' > 'azab')
print('你好' < 'abc')
判斷一個(gè)字符是否是數(shù)字字符妒潭,判斷一個(gè)字符是否是字母字符
char = 'H'
print('0'<=char<='9') # 判斷char是否是數(shù)字字符
print('a'<=char<='z' or 'A'<=char<='Z') # char是否是字母
4.in和not in
字符串1 in 字符串2 ---> 判斷字符串1是否在字符串2中(字符串2中是否包含字符串1)涯雅,結(jié)果是布爾值
print('ab' in 'aaabc') # True
print('ab' in 'acb') # False
print('ab' not in 'aaabc') # False
print('ab' not in 'acb') # True
5.len()函數(shù)
len是python內(nèi)置函數(shù)柑贞,功能是用來(lái)獲取序列的長(zhǎng)度(容器中元素的個(gè)數(shù))
len(序列)
字符串的長(zhǎng)度就是字符串中字符的個(gè)數(shù)
print(len('hello'))
str5 = '床前明月光\n疑是地上霜!'
print(len(str5))
str5 = r'床前明月光\n疑是地上霜!'
print(len(str5))
str5 = '你好嗎移层?\u4eff\u5cff'
print(len(str5))
print(str5[len(str5)-1]) # str5[5]
print(str5[-len(str5)])
3.格式字符串
格式字符串
字符串的內(nèi)部拐袜,通過(guò)格式占位符來(lái)表示字符串中變化的部分,然后在后面用值來(lái)填充變化的部分
語(yǔ)法: 帶有占位符的字符串 % (給占位符賦值的值)
注意:前面有多少個(gè)占位符谎亩,后邊()中就必須有多少值炒嘲。并且值的個(gè)數(shù)和值的類型要和前面的占位符一一對(duì)應(yīng)
%s ----> 字符串
%d ----> 整數(shù)
%f ----> 小數(shù)
%.nf ----> 保留小數(shù)點(diǎn)后n位小數(shù)(五舍六入)
%c ----> 字符
name = '李四'
age = 20
money = 10.567
# message = '姓名:'+name+' 年齡:'+str(age)+' 薪資:'+ str(money)
message = '姓名:%s 年齡:%d 薪資:%.2f' % (name, age, money)
print(message)
print('%d:%c' % (97, 97))
4.字符串內(nèi)置函數(shù)
python內(nèi)部給我們提供很多字符串相關(guān)的方法,使用方式:字符串.方法名(參數(shù))
1.
capitalize() : 將字符串的第一個(gè)字符轉(zhuǎn)換為大寫,返回一個(gè)新的字符串;如果第一個(gè)字符不是字母匈庭,就不轉(zhuǎn)換
str1 = 'love'
new_str = str1.capitalize()
print(new_str)
2.字符串對(duì)齊
a.center(width, fillchar)
b.ljust(width, fillchar)
c.rjust(width, fillchar)
width --> 長(zhǎng)度夫凸,新的字符串的總共的長(zhǎng)度 fillchar --> 剩下部分填充的字符。字符就是長(zhǎng)度是1的字符串
str2 = 'XXX'
new_str = str2.center(7, '0') # 00XXX00
print(new_str)
new_str = str2.ljust(7, '*') # XXX****
print(new_str)
new_str = str2.rjust(7, 'A') # AAAAXXX
print(new_str)
練習(xí):根據(jù)進(jìn)班的順序號(hào)產(chǎn)生對(duì)應(yīng)的學(xué)號(hào)阱持,學(xué)號(hào)要求:
例如:num = 1 ----> py18070001 num = 11 ---> py18070011
num = 19
new = 'py1807'+str(num).rjust(4, '0')
print(new)
3.
字符串1.count(字符串2) ---> 統(tǒng)計(jì)字符串1中字符串2的個(gè)數(shù)
print('abcdabcdaaa'.count('ab'))
print('hello wolrd'.count('l'))
4.
字符串1.endswith(字符串2) ---> 判斷字符串1是否以字符串2結(jié)尾
字符串1.startswith(字符串2) ---> 判斷字符串1是否以字符串2開(kāi)頭
str1 = 'when i was'
print(str1.endswith('was'))
print(str1.endswith('when'))
5.
字符串1.find(字符串2) ---> 在字符串1中查到字符串2夭拌,返回第一個(gè)的開(kāi)始下標(biāo)。如果沒(méi)有就返回-1
str1 = 'was when i was young,was i have a dream Z'
print(str1.find('was'))
print(str1.find('wasaa'))
print(str1.find('Z'), len(str1))
6.isTitle()
標(biāo)題化:每個(gè)單詞首字母大寫,其他字母小寫
print('The One'.istitle())
7.
字符串1.join(字符串2) ---> 將字符串1插入到字符串2中每個(gè)字符之間,產(chǎn)生一個(gè)新的字符串
print('aa'.join('xbcud'))