日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

Python学习3 字符串和相关常用函数

發布時間:2023/12/13 python 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python学习3 字符串和相关常用函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

字符串聲明

雙引號,單引號,三單引號,三雙引號
里面有雙引號,外面使用單引號
里面有單引號,外面使用雙引號
或者使用轉義字符

#字符串 m='hello' n="hello" #里面有雙引號,外面使用單引號 a='"hello"' #里面有單引號,外面使用雙引號 b="I'm dq" c='''hello''' d="""hello"""i='''I say:"ok"''' j="""I'dq"""print(a,b,c,d,i,j,sep='\n')

注意:不能字符串+數字,會報錯,必須兩者都是字符串

#報錯TypeError: can only concatenate str (not "int") to str print("3243"+3) print("3243" + 3+"2343")

規定:
兩個字符串類型的數據使用加法運算符,用來拼接兩個字符串。在Python里數字和字符串不能做加法運算。

數字和字符串之間使用乘法運算符,用于將字符串重復多次。

字符串之間使用比較運算符,會根據各個字符的編碼值逐一進行比較。

數字和字符串之間,做 == 運算的結果是 False,做 != 運算的結果是 True,其它的比較運算均不支持,否則會報錯。

易錯題:

#2
print(‘127’+‘124’)
#真實情況下輸出127124,但答題的時候加上‘’

1)

2)

3)

轉義字符

\n換行
\t水平制表符
\斜杠
\r是回車,光標到行首
\v:垂直制表
如:
aaaa水平

a
a
a
a垂直
tab默認四個空格

#字符串2-轉義字符 m='he\'ll\'o' n="he\"ll\"o" print(m,n,sep='\n')

格式化打印字符串

格式化打印字符串有兩種方式:
1.可以使用 % 占位符來表示格式化一個字符串。
%s == > 字符串占位符。
%d == > 整數占位符。
%nd == > 打印時顯示 n 位,如果不夠,在前面使用空格補齊。
%f == > 浮點數占位符。
%. nf == > 保留小數點后 n 位。
%x == > 將數字使用十六進制輸出。
%% == > 輸出一個 % 。

2.format()方式

字符串下標

1.字符串下標
0–n-1
-n-(-1)

2.字符串一旦定義不能發生變化
x=‘89’
x[0]=‘3’(錯誤)
x=‘2345’(指向一個新的字符串)

3.字符串切片
字符串名稱[start :end :step]
【start,end)
step默認為1,從左往右取
如果只設置start,會“截取”到最后。
如果只設置end,會從頭開始“截取”到end前一個字符。
這三個都可以缺省,即取出所有的

正向:

#字符串3-切片1 x='1234567' #[start:end)從0開始-12 print(x[0:2:1],sep='\n') #[start:end)從0開始-1234567 print(x[0:7:1],sep='\n') #全部缺省,取出所有的-1234567 print(x[::],sep='\n') #取出[1,3)--123 print(x[:3:],sep='\n') #隔2個取--1357 print(x[0::2],sep='\n')

逆向:
step=-1從右往左取

#字符串3-切片2 x='1234567' #(-n)--(-1):這里-7--(-1) #step=1從左向右--34 print(x[-5:-3:1],sep='\n') #step=-1從右到左,7654 print(x[-1:-5:-1],sep='\n') #從第-2到第-5,從右往左,每隔兩個字符做1次切片,輸出64 print(x[-2:-5:-2]) ##從右往左每隔3個字符做1次切片,輸出741 print(x[::-3],sep='\n')

易錯題:
只有單個數字【n】,是取出單個字符

#3 s="abcdef" #【-6,-1】 #【0,5】 print(s[3],s[-3],s[0:-3],s[:-3],sep='\n') #輸出 # d # d--(-3)從右到左第三個-1,-2,-3 # abc--【0,-3)從頭開始,到第三個字符-6,-5,-4 # abc--從頭開始,到第三個字符 #4 s="ABCDEFG" #[0,6] #[-7,-1] print(s[4],s[-4],s[0:-4],s[:-4],sep="\n") #-7-6-5-4-3-2-1 #0123456 #對應ABC #s[4]--E #s[-4]--D #s[0:-4]--ABC[0,-4) #s[:-4]--ABC[0,-4)

字符串常見函數

獲取字符串長度-len()函數

查找內容-find()函數

描述:查找字符串中指定的子字符串sub第一次出現的位置,可以規定字符串的索引查找范圍。若無則返回 -1。

語法:str.find(sub,start,end) -> int 返回整數
sum —要索引的子字符串。
start —索引的起始位置。默認值為0。
end —索引的結束位置。默認值為字符串長度len(str)。
[start,end) 不包括end。

#字符串函數-find x='i love python' #語法:字符串名稱。find(子字符串,開始位置,結束位置) #返回字符子串python第一次出現的位置(下標,從0開始) print(x.find('python',0,len(x)),end='\n') #沒有查找到就返回-1 print(x.find('python',0,6),end='\n')

查找內容-rfind()函數

描述:查找字符串中指定的子字符串sub最后一次出現的位置,可以規定字符串的索引查找范圍。若無則返回 -1。

語法:str.rfind(sub,start,end) -> int 返回整數
sum —要索引的子字符串。
start —索引的起始位置。默認值為0。
end —索引的結束位置。默認值為字符串長度len(str)。
[start,end) 不包括end。

注:rfind()函數用法與find()函數相似,rfind()函數返回指定子字符串最后一次出現的位置,find()函數返回指定子字符串第一次出現的位置。

#字符串函數-rfind x='ip lovnep python' #語法:字符串名稱。find(子字符串,開始位置,結束位置) #返回字符子串python最后一次出現的位置(下標,從0開始)--n print(x.rfind('n',0,len(x)),end='\n') #查的是第一個字符:p--10 print(x.rfind("python")) #沒有查找到就返回-1 print(x.rfind('python',0,6),end='\n')

查找內容-index()函數

描述:查找字符串中第一次出現的子字符串的位置,可以規定字符串的索引查找范圍[star,end)。若無則會報錯。

語法:str.index(sub, start, end) -> int 返回整數
sub —— 查找的子字符串。
start —— 索引的起始位置,默認為0。
end —— 索引的結束位置,默認為字符串的長度。
[star,end)

# 字符串函數-index str = "i love python" # 與find用法一致 print(str.index("p", 4, 12)) # 若無則會報錯-ValueError: substring not found print(str.index("k", 4, 12)) print(str.index("i"))

查找內容-rindex()函數

描述:查找字符串中最后一次出現的子字符串的位置,可以規定字符串的索引查找范圍[star,end),若無則會報錯。

語法:str.rindex(sub, start, end) -> int 返回整數。
sub —— 查找的子字符串。
start —— 索引的起始位置,默認為0。
end —— 索引的結束位置,默認為字符串的長度。
[star,end)

#字符串函數-rindex str = "i love python python" #返回字符子串p后一次出現的位置(下標,從0開始) print(str.rindex("p")) #返回字符子串o后一次出現的位置(下標,從0開始) print(str.rindex("o",0,len(str))) # 若無則會報錯-ValueError: substring not found print(str.rindex("x"))

判斷-endswith()函數

描述:判斷字符串是否以指定字符或子字符串結尾。

語法:str.endswith(“suffix”, start, end) 或
str[start,end].endswith(“suffix”) 用于判斷字符串中某段字符串是否以指定字符或子字符串結尾。
—> bool 返回值為布爾類型(True,False)
suffix — 后綴,可以是單個字符,也可以是字符串,還可以是元組("suffix"中的引號要省略)。
start —索引字符串的起始位置。
end — 索引字符串的結束位置。
str.endswith(suffix) star默認為0,end默認為字符串的長度減一(len(str)-1)。
注意:空字符的情況。返回值通常也為True

#字符串函數-endswith #查找字符串是否以字符結尾,是返回True,不是返回False str = "i love python" #True print(str.endswith("n")) #False print(str.endswith("n",0,6)) #True print(str.endswith("python")) #True print(str.endswith("python",0,len(str))) #True-空字符串 print(str.endswith(""))

判斷-startswith()函數

描述:判斷字符串是否以指定字符或子字符串開頭。
用法與endswitch一致

#字符串函數-startswith #查找字符串是否以字符開頭,是返回True,不是返回False str = "ilove python" #True print(str.startswith("i")) #True print(str.startswith("i",0,6)) #True print(str.startswith("ilove")) #False print(str.startswith("python",0,len(str))) #True-空字符串 print(str.startswith(""))

判斷-isalpha()函數

isalpha()的作用是檢查一個字符串中所有的字符是否都是由字母構成的,并且至少有1個字符。
string_name.isalpha()

該函數沒有參數。
string_name是要判斷的字符串或字符串變量。
如果字符串中除了字母和中文外,不包括任何其它字符(數字,符號等)且不是空字符串,則返回True,否則返回False.
示例:

判斷- isdigit() 函數

isdigit()方法檢測字符串是否只由數字組成。
如果字符串只包含數字則返回 True 否則返回 False。

str = "123456" #True print (str.isdigit())str = "this is string example....wow!!!"#False print (str.isdigit())str = "thisd22is string example....wow!!!"#False print (str.isdigit()) str = "可靠 11"#False print (str.isdigit())

判斷-isalnum()函數

檢查一個字符串是否是由某門語言的有效字符或數字構成。
1)該函數檢查字符串是否由字母[a-z,A-Z](也包括構成其它語言的字符,如漢字,俄文,日文,韓文)或數字[0-9]及其組合組成的,如果是則返回True,否則返回False。

3)組成字符串的字符中有是空字符串,不能有特殊字符,不可打印字符,控制符,標點符號等返回False。

isalnum使用的例子 1、字符串僅包含字母str1 = "Python" print(str1.isalnum())輸出:True2、字符串僅包含數字str1 = "5211314" print(str1.isalnum())輸出:True3、字符串由字母或數字組成str1 = "HelloPython3" print(str1.isalnum())輸出:True4、字符串由字母和漢字組成rtn_value = "翔宇亭IT樂園".isalnum() print(rtn_value)輸出:True只包括漢字和英文字母,所以為True.5、字符串中包含空格str1 = "I am a student" print(str1.isalnum())輸出:False6、字符串中包含標點符號str1 = "Perfect!" print(str1.isalnum())輸出:False7、字符串中包含大小寫的字母str1 = "GoodBoy123" print(str1.isalnum())輸出:True8、空字符str1 = "" print(str1.isalnum())輸出:False9、非英文字母str1 = "Ятебялюблю" #俄語 print(str1.isalnum())輸出:True10、包含特殊字符str1 = "Hello@biye5u" print(str1.isalnum())輸出:False

判斷-isspace()函數

isspace()的作用是檢查字符串是否僅包含空白字符(純空白字符”“,’‘,轉義字符\n,\t,\v,\r),如果字符串僅包含空白字符則返回True,否則返回False。

示例1:

示例2:

計算-出現次數count()函數

描述:統計字符串里某個字符出現的次數。可以選擇字符串索引的起始位置和結束位置。

str = "i love python,i am learning python"print(str.count("i"))print(str.count("i",2))print(str.count("i",2,5))print(str.count("am"))

替換內容-replace()函數

replace() 方法把字符串中的 old(舊字符串) 替換成 new(新字符串),如果指定第三個參數max,則替換不超過 max 次。

str.replace(old, new[, max])
old – 將被替換的子字符串。

new – 新字符串,用于替換old子字符串。

max – 可選字符串, 替換不超過 max 次

返回字符串中的 old(舊字符串) 替換成 new(新字符串)后生成的新字符串,如果指定第三個參數max,則替換不超過 max 次。

實例 str = "this is string example....wow!!! this is really string" print (str.replace("is", "was")) print (str.replace("is", "was", 3)) 輸出:thwas was string example…wow!!! thwas was really stringthwas was string example…wow!!! thwas is really string

易錯題:
字符串下標從0開始

a="abcd" print(a) str=a.replace('a','e') #改變的不是原字符串 print(a) print(str)#是生成一個新字符串a='e'+a[1:] print(a)

切割字符串-partition()函數:

描述:根據指定的分隔符(sep)將字符串進行分割。從字符串左邊開始索引分隔符sep,索引到則停止索引。

語法:str.partition(sep) -> (head, sep, tail) 返回一個三元元組,head:分隔符sep前的字符串,sep:分隔符本身,tail:分隔符sep后的字符串。

#字符串-partition #partition('分隔符')指定的分隔符(sep)將字符串進行分割 #遇到第一個分隔符就停止 #有:返回(分隔符左邊,分隔符,分隔符右邊) #無:返回(整個字符串,分隔符) str = "https://www.baidu.com/"print(str.partition("://")) print(str.partition(",")) print(str.partition(".")) print(type(str.partition("://"))) # 輸出: # ('https', '://', 'www.baidu.com/') # ('https://www.baidu.com/', '', '') # ('https://www', '.', 'baidu.com/') # <class 'tuple'>

切割字符串-rpartition()函數

描述:根據指定的分隔符(sep)將字符串進行分割。從字符串右邊(末尾)開始索引分隔符sep,索引到則停止索引。

語法:str.rpartition(sep) -> (head, sep, tail) 返回一個三元元組,head:分隔符sep前的字符串,sep:分隔符本身,tail:分隔符sep后的字符串。

#字符串-rpartition #rpartition('分隔符')指定的分隔符(sep)將字符串進行分割--從右往左 #遇到第一個分隔符就停止 #有:返回(分隔符左邊,分隔符,分隔符右邊) #無:返回(分隔符,整個字符串) str = "https://www.baidu.com/"print(str.rpartition("://")) print(str.rpartition(",")) print(str.rpartition(".")) print(type(str.rpartition("://"))) # 輸出: # ('https', '://', 'www.baidu.com/') # ('', '', 'https://www.baidu.com/') # ('https://www.baidu', '.', 'com/') # <class 'tuple'>

切割字符串-split()函數

描述:拆分字符串。通過指定分隔符sep對字符串進行分割,并返回分割后的字符串列表。

語法:str.split(sep=None, maxsplit=-1) -> list of strings 返回 字符串列表 或str.split(sep=None, maxsplit=-1)[n]

sep —— 分隔符,默認為空格,但不能為空即(")。
maxsplit —— 最大分割參數,默認參數為-1。
[n] —— 返回列表中下標為n的元素。列表索引的用法。

#字符串函數-split() a="d/q.i/s.co/ding" #沒有分割,輸出整個字符串--['dqiscoding'] print(a.split()) #以.分割--['dq', 'is', 'coding'] print(a.split(".")) #分割后的字符串的第一個,再次分割,從0開始 print(a.split('.')[0].split('/')) print(a.split('.')[1].split('/'))

切割字符串-rsplit()函數

rsplit() 方法通過指定分隔符對字符串進行分割并返回一個列表,默認分隔符為所有空字符,包括空格、換行(\n)、制表符(\t)等。類似于 split() 方法,只不過是從字符串最后面開始分割。

#字符串函數-rsplit() #從字符串最后面開始分割,但輸出時還是從前面往后輸出 a="d/q.i/s.co/ding" #沒有分割,輸出整個字符串--['dqiscoding'] print(a.rsplit()) #以.分割--['dq', 'is', 'coding'] print(a.rsplit(".")) #1為最大分割次數,此時只分割一次 print(a.rsplit(".",1)) #分割后的字符串的第一個,再次分割,從0開始 print(a.rsplit('.')[0].rsplit('/')) print(a.rsplit('.')[1].rsplit('/'))

切割字符串-splitlines()函數

splitline()方法用于在線邊界處分割線。該函數返回字符串中的行列表,包括換行符(可選)。

用法:

string.splitlines([keepends])
參數:
keepends(可選):當設置為True時,結果列表中將包含換行符。
這可以是一個數字,指定換行的位置,也可以是任何Unicode字符,例如“\n”,“\r”,“\r\n”等作為字符串的邊界。

代碼#1

string = “Welcome everyone to\rthe world of Geeks\nGeeksforGeeks”
print (string.splitlines( ))
print (string.splitlines(0))
print (string.splitlines(True))

輸出:

[‘Welcome everyone to’, ‘the world of Geeks’, ‘GeeksforGeeks’]

[‘Welcome everyone to’, ‘the world of Geeks’, ‘GeeksforGeeks’]

[‘Welcome everyone to\r’, ‘the world of Geeks\n’, ‘GeeksforGeeks’]

代碼#2

string = “Cat\nBat\nSat\nMat\nXat\nEat”

print (string.splitlines( ))
print(‘India\nJapan\nUSA\nUK\nCanada\n’.splitlines())

輸出:

[‘Cat’, ‘Bat’, ‘Sat’, ‘Mat’, ‘Xat’, ‘Eat’]

[‘India’, ‘Japan’, ‘USA’, ‘UK’, ‘Canada’]

修改大小寫-capitalize()函數

描述:將字符串的第一個字母變成大寫,其余字母變為小寫。

語法:str.capitalize() —> str 返回字符串

程序示例:

str1 = "i Love python"str2 = " i Love python"str3 = "I Love python"print(str1.capitalize())print(str2.capitalize())print(str3.capitalize())程序運行結果: I love pythoni love pythonI love python

修改大小寫-title()函數

描述:返回一個滿足標題格式的字符串。即所有英文單詞首字母大寫,其余英文字母小寫。

語法:str.title() -> str 返回一個字符串

程序示例:

str = "i love python"print(str.title())程序運行結果: I Love Python

修改大小寫-upper()函數

描述:將字符串中的所有小寫字母轉換為大寫字母。

語法:str.upper() -> str 返回字符串

程序示例:

str1 = "i love python" str2 = "I Love Python" print(str1.upper())print(str2.upper())程序運行結果: I LOVE PYTHONI LOVE PYTHON

修改大小寫-lower()函數

描述:將字符串中的所有大寫字母轉換為小寫字母。

語法:str.lower() -> str 返回字符串

程序示例:

str1 = "I Love Python"str2 = "Gro? - α" print(str1.lower()) print(str2.lower())程序運行結果:i love python gro? - α

空格處理-ljust()函數

描述:返回一個原字符串左對齊,并使用fillchar填充(默認為空格)至指定長度的新字符串。如果指定的長度小于原字符串的長度則返回原字符串。

語法:str.ljust(width, fillchar) -> str 返回一個新的字符串

width —— 指定字符串的輸出長度。

fillchar—— 將要填充的單字符,默認為空格。

程序示例:

str = "python"print(str.ljust(30,"*"))print(str.ljust(30))print(str.ljust(30),"1")程序運行結果: python************************pythonpython 1

空格處理- rjust()函數

描述:返回一個原字符串右對齊,并使用fillchar填充(默認為空格)至指定長度的新字符串。如果指定的長度小于原字符串的長度則返回原字符串。

語法:str.ljust(width, fillchar) -> str 返回一個新的字符串

width —— 指定字符串的輸出長度。

fillchar—— 將要填充的單字符,默認為空格。

程序示例: str = "python"print(str.rjust(30,"*"))print(str.rjust(30))print("1",str.rjust(30))程序運行結果: ************************pythonpython1 python

空格處理-center()函數

描述:返回一個長度為width,兩邊用fillchar(單字符)填充的字符串,即字符串str居中,兩邊用fillchar填充。若字符串的長度大于width,則直接返回字符串str。

語法:str.center(width , “fillchar”) -> str 返回字符串 注意:引號不可省

width —— 指定字符串長度。

fillchar —— 要填充的單字符,默認為空格。

程序示例:

str = "i love python"print(str.center(20,"*"))print(str.center(1,"*"))print(str.center(20,"8"))print(str.center(20))程序運行結果: ***i love python****i love python888i love python8888i love python

空格處理–strip()函數

描述:從字符串str中去掉在其左右兩邊chars中列出的字符。

注:chars傳入的是一個字符數組,編譯器去除兩端所有相應的字符,直到出現第一個在chars中不匹配的字符。詳看示例。

語法:str.strip(chars) -> str 返回一個新的字符串
chars —— 要去除的字符 默認為空格或換行符。

#字符串函數-strip str = "123456789321" #strip()從字符串str中去掉在其左右兩邊chars中列出的字符 #去掉了兩邊包含123的字符--456789 print(str.strip("123")) str1 = "my name is ymyyyy" #去掉了兩邊包含myis空格的字符--name print(str1.strip("my is")) print(str1.strip("my "))

空格處理–lstrip()函數

描述:從字符串str中去掉在其左邊chars中列出的字符。

#字符串函數-lstrip #去掉左邊列出的字符,直到遇到第一個在chars中不匹配的字符 str1 = "bacjabck123kluabc" print(str1.lstrip("abc")) str2 = "12578asdfgh12" print(str2.lstrip("12"))

空格處理-rstrip()函數

描述:從字符串str中去掉在其右邊chars中列出的字符。

#字符串函數-rstrip #去掉右邊列出的字符,直到遇到第一個在chars中不匹配的字符 str1 = "bacjabck123kluabc" print(str1.rstrip("abc")) str2 = "12578asdfgh12" print(str2.rstrip("12"))

字符串拼接-join()函數

join(): 連接字符串數組。將字符串、元組、列表中的元素以指定的字符(分隔符)連接生成一個新的字符串
語法: ‘sep’.join(seq)

參數說明
sep:分隔符。可以為空
seq:要連接的元素序列、字符串、元組、字典
上面的語法即:以sep作為分隔符,將seq所有的元素合并成一個新的字符串

返回值:返回一個以分隔符sep連接各個元素后生成的字符串

#對字符串進行操作>>> seq2 = "hello good boy doiido" >>> print ':'.join(seq2) h:e:l:l:o: :g:o:o:d: :b:o:y: :d:o:i:i:d:o

maketrans()方法

描述
maketrans() 方法用于創建字符映射的轉換表,對于接受兩個參數的最簡單的調用方式,第一個參數是字符串,表示需要轉換的字符,第二個參數也是字符串表示轉換的目標。

兩個字符串的長度必須相同,為一一對應的關系。
maketrans()方法語法:
str.maketrans(intab, outtab)
參數
intab – 字符串中要替代的字符組成的字符串。
outtab – 相應的映射字符的字符串。
返回值
返回字符串轉換后生成的新字符串。
使用maketrans() 方法將所有元音字母轉換為指定的數字:

intab = "aeiou" outtab = "12345" trantab = str.maketrans(intab, outtab)str = "this is string example....wow!!!" print (str.translate(trantab)) 以上實例輸出結果如下: th3s 3s str3ng 2x1mpl2....w4w!!!

總結

以上是生活随笔為你收集整理的Python学习3 字符串和相关常用函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。