2018-09-28字符串元素、字符串運(yùn)算、格式字符串和字符串內(nèi)置函數(shù)

1.阻止轉(zhuǎn)義

  • 在字符串的最前面可以添加r/R來阻止字符串中的轉(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è)字符的位置不可變)
str2 = 'hello'

3.獲取字符串中的單個(gè)字符

語法: 字符串[下標(biāo)] ---> 根據(jù)下標(biāo)獲取字符串中的字符
說明: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)

str3 = 'python'

p->0  y->1  t->2  h->3 ....n->5
n->-1 o->-2  h->-3....p->-6
print(str3[0])
print(str3[-6])

print(str3[4])     # 獲取倒數(shù)第4+1個(gè)字符(元素)
print(str3[-2])    # 獲取倒數(shù)第2個(gè)字符(元素)

print('hello'[-1])

index = 2
print(str3[index])
print(str3[6//2])

練習(xí):獲取'good good study\n day day up!'
注意:一個(gè)空格算一個(gè)字符, 一個(gè)轉(zhuǎn)義字符算一個(gè)字符,一個(gè)制表符也是算一個(gè)字符

str4 = 'good good study\n day day up!'
print(str4[17], str4[-11])  
print('abc'[3])  # IndexError: string index out of range
print('abc'[-5])   # IndexError: string index out of range

4.獲取字符串中的部分字符(切片)

a.

語法:字符串[起始下標(biāo):結(jié)束下標(biāo)] --> 獲取字符串中從起始下標(biāo)開始,到結(jié)束下標(biāo)前的所有的字符
默認(rèn)步長(zhǎng)為1
注意:起始下標(biāo)對(duì)應(yīng)的字符要在結(jié)束下標(biāo)對(duì)應(yīng)的字符的前面,否取不到值

str5 = '同九年,汝何秀!'
print(str5[1:5])
print(str5[5:-1])

b.

語法:字符串[起始下標(biāo):結(jié)束下標(biāo):步長(zhǎng)] --> 從起始下標(biāo)開始獲取,每步長(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)的字符的后面,否取不到值)

str5 = '海賊王、一拳超人、一人之下、進(jìn)擊的巨人'
print(str5[1:10:2])   # 賊、拳人一
print(str5[10:0:-1])  # 人一、人超拳..賊

c.切片時(shí)下標(biāo)可以省略,省略不同的下標(biāo)有不同的意義

省略起始下標(biāo): 字符串[:結(jié)束下標(biāo)] ----> 從開頭開始取 (注意:這兒開頭可能是第一個(gè)字符也可能是最后一個(gè)字符)

str6 = '閣下何不同風(fēng)起,扶搖直上九萬里'

print(str6[:4])
print(str6[:4:-1])  

省略結(jié)束下標(biāo): 字符[起始下標(biāo):] ---> 從開始下標(biāo)取,取完為止

print(str6[-4:])
print(str6[-4::-1])  

兩個(gè)下標(biāo)都?。?字符[:] ----> 全部取完

print(str6[:])
print(str6[::-1])   # 產(chǎn)生一個(gè)逆序的字符串
print(str6)
str7 = str6[::-1]
print(str7)

注意:切片的時(shí)候下標(biāo)可以越界

print(str6[0:100])
print(str6[-100:3])  
  • python中的字符串支持+、*和比較運(yùn)算符
    1. 字符串的+號(hào)運(yùn)算符
  • 字符串1 + 字符串2 ----> 將字符串1和字符串2拼接在一起產(chǎn)生一個(gè)新的字符串
    注意:+兩邊要么都是數(shù)字,要么都是字符串,不能一樣一個(gè)
str1 = '玉樹臨風(fēng)美少年'
str2 = '攬鏡自顧夜不眠'
print(str1 + str2)
new_str = str1 + ' ' + str2 + '!'
print(new_str)
print(str1 + ',' + str2)  

字符串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è)字符是否是字母字符
print('===========')
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ù),功能是用來獲取序列的長(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)])
  • 格式字符串
  • 字符串的內(nèi)部,通過格式占位符來表示字符串中變化的部分,然后在后面用值來填充變化的部分
  • 語法: 帶有占位符的字符串 % (給占位符賦值的值)
  • 注意:前面有多少個(gè)占位符,后邊()中就必須有多少值。并且值的個(gè)數(shù)和值的類型要和前面的占位符一一對(duì)應(yīng)
符號(hào) 意義
%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))

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 = 102 -- py18070102
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開頭
str1 = 'when i was'
print(str1.endswith('was'))
print(str1.endswith('when'))

5.字符串1.find(字符串2) ---> 在字符串1中查到字符串2,返回第一個(gè)的開始下標(biāo)。如果沒有就返回-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.isnumeric()

    print('1234'.isnumeric())
    print('一二五七九'.isnumeric())
    print('二百五'.isnumeric())
    print('壹萬'.isnumeric())

7.isTitle()

  • 標(biāo)題化:每個(gè)單詞首字母大寫,其他字母小寫

print('The One'.istitle())

8.字符串1.join(字符串2) ---> 將字符串1插入到字符串2中每個(gè)字符之間,產(chǎn)生一個(gè)新的字符串

print('aa'.join('xbcud'))

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容