1. 索引(即下標)
s = 'ABCDEFGHIJKLMN' s1 = s[0] print('s[0] = ' + s1) #s[0] = A print('s[3] = '+ s[3]) #s[3] = D print('倒數第三個數為:' + s[-3]) #倒數第三個數為:L print('最后一個數為:' + s[-1]) #最后一個數為:N
2. 切片:顧頭不顧尾
s = 'ABCDEFGHIJKLMN' s2 = s[0:3] print('s[0:3] = ' + s2) #s[0:3] = ABC print('整個字符串如下:' + s[:]) #整個字符串如下:ABCDEFGHIJKLMN print('整個字符串如下:' + s[0:]) #整個字符串如下:ABCDEFGHIJKLMN print('前兩個字符:' + s[:2]) #前兩個字符:AB
3. 跳取 s[首:尾:步長]
s3 = 'ABCDEFGHIJKLMN' print(s3[0:6:2]) #ACE print(s3[::2]) #ACEGIKM print(s3[4:0:-1]) #倒着取:EDCB print(s3[3::-1]) #DCBA print(s3[-1::-1]) #NMLKJIHGFEDCBA
4. 字符串的操作
(1)首字母大寫
s = 'alexWUsir' s4_1 = s.capitalize() #首字母大寫 print(s4_1) #Alexwusir
(2)全部大寫
s = 'alexWUsir' s4_2 = s.upper() #全部大寫 print(s4_2) #ALEXWUSIR
(3)全部小寫
s = 'alexWUsir' s4_3 = s.lower() #全部小寫 print(s4_3) #alexwusir
(4)大小寫互換
s = 'alexWUsir' s4_4 = s.swapcase() #大小寫互換 print(s4_4) #ALEXwuSIR
5. 居中(用空白/其他字符填充)
#center(self, width, fillchar=None)
s = 'alexWUsir' s5_1 = s.center(20,'%') #用%填充 s5_2 = s.center(15,'*') #用*填充 s5_3 = s.center(20) #空白填充 print(s5_1) #%%%%%alexWUsir%%%%%% print(s5_2) #***alexWUsir*** print(s5_3) # alexWUsir
6. 從開始到\t自動補全到8位16位等等
s = 'alex\tsir' ss = 'alfhgjjfdex\tsir' s6_1 = s.expandtabs() s6_2 = ss.expandtabs() print(s6_1) #alex sir:\t之前少於8位則自動補全到8位 print(s6_2) #alfhgjjfdex sir:\t之前大於8位少於16位則自動補全到16位
7. 每個用特殊字符或數字隔開的單詞首字母大寫
s = 'xc——gx*zs_shy+hihn9bbklv yiu' s7 = s.title() print(s7) #Xc——Gx*Zs_Shy+Hihn9Bbklv Yiu
應用實例:
print('-------------- 驗證碼的檢驗問題(先轉化為全部大寫,再核對) --------------') s_str = 'aBcD1s' you_input = input('請輸入驗證碼,不區分大小寫') while s_str.upper()!= you_input.upper(): print('驗證碼錯誤') you_input = input('請重新輸入') print('輸入成功')
運行結果:
8. 查找
#s.find通過元素找索引,找到返回索引,找不到返回-1 #s.index通過元素找索引,找到返回索引,找不到返回error s = 'alexWUsir' s8_11 = s.find('W') s8_12 = s.index('W') s8_21 = s.find('WU') s8_22 = s.index('WU') s8_31 = s.find('A') s8_32 = s.index('A') print(s8_11,type(s8_12)) #4 <class 'int'> print(s8_21 ,type(s8_22)) #4 <class 'int'> print(s8_31 ,type(s8_32)) #報錯:ValueError: substring not found----未找到子字符串
應用實例:
print('----------------檢驗非法(敏感)字符-------------------') s = 'gcu習大大gckhb' if '習大大' in s: print('您的評論有敏感字符')
運行結果:
9. 刪除字符串前后的空格/字符
s = ' alexW%Usir %2% ' s9_1 = s.strip() #刪除字符串前后的空格 print(s9_1) #alexW%Usir %2% ss = '% alexW%Usir %2% %' s9_2 = ss.strip('%') #刪除字符串前后的% print(s9_2) # alexW%Usir %2%
應用舉例:
username = input('請輸入名字:').strip() if username == '辛辰': print('你好呀 主人')
運行結果:
10. 計算字符串中某字符/字符串的個數
s = 'alexaa wusirl' s10 = s.count('a') print('此字符串中有' + s10 + '個a') #報錯:TypeError: must be str, not int print('此字符串中有' + str(s10) + '個a') #此字符串中有3個a
11. 分割:用空格(默認)/固定字符分割字符串(相當於str--->list)
s = 'alex wusir taibai' s1 = 'ale:x wus:ir :taibai' s11_1 = s.split() print(s11_1) #['alex', 'wusir', 'taibai'] s11_2 = s1.split(':') print(s11_2) #['ale', 'x wus', 'ir ', 'taibai']
12. 三種格式化輸出format
s12_1 = '我叫{},今年{}歲,愛好{},再說一下我叫{}'.format('辛辰',23,'學習','辛辰') print(s12_1) #我叫辛辰,今年23歲,愛好學習,再說一下我叫辛辰 s12_2 = '我叫{0},今年{1}歲,愛好{2},再說一下我叫{0}'.format('辛辰',23,'學習') print(s12_2) #我叫辛辰,今年23歲,愛好學習,再說一下我叫辛辰 s12_3 = s1 = '我叫{name},今年{age}歲,愛好{hobby},再說一下我叫{name}'.format(name = '辛辰',age = 23,hobby = '學習') print(s12_3) #我叫辛辰,今年23歲,愛好學習,再說一下我叫辛辰
13. replace 字符串的替換
s13_1 = '辛辰,哈嘍你好,我是辛辰' s13_2 = s13_1.replace('辛辰','陳欣') s13_3 = s13_1.replace('辛辰','陳欣',1) print(s13_1) #辛辰,哈嘍你好,我是辛辰----原來文本 print(s13_2) #陳欣,哈嘍你好,我是陳欣----全都替換 print(s13_3) #陳欣,哈嘍你好,我是辛辰----只替換第一個
14. is系列
s14 = '' print(s14.isdigit()) #是否由數字組成 print(s14.isalpha()) #是否由字母組成 print(s14.isalnum()) #是否由字母或數字組成 s14_1 = 'zxcs' s14_2 = '123546' s14_3 = 'c1d21c4' print('----------s14_1----------') print(s14_1.isdigit()) #False print(s14_1.isalpha()) #True print(s14_1.isalnum()) #True print('----------s14_2----------') print(s14_2.isdigit()) #True print(s14_2.isalpha()) #False print(s14_2.isalnum()) #True print('----------s14_3----------') print(s14_3.isdigit()) #False print(s14_3.isalpha()) #False print(s14_3.isalnum()) #True #判斷字符串是否全是空格 s14_4 = ' n ' s14_5 = '' s14_6 = ' ' print(s14_4.isspace()) #False:有除空格外的其他字符 print(s14_5.isspace()) #False:空 print(s14_6.isspace()) #True:全是空格
15. 有限循環for(while是無限循環)
s = 'xinchen' for i in s: print(i) #舉例: s = 'fhdsklfds' if 'sk' in s: print('非法') print('------------------------') if 'skk' not in s: print('合法')