關於Python中字符串的各種操作

1、字符串拼接

通過+運算符
現有字符串碼農飛哥好,,要求將字符串碼農飛哥牛逼拼接到其後面,生成新的字符串碼農飛哥好,碼農飛哥牛逼

舉個例子:

str6 = '碼農飛哥好,'
# 使用+ 運算符號
print('+運算符拼接的結果=',(str6 + '碼農飛哥牛逼'))

運行結果是:

+運算符拼接的結果= 碼農飛哥好,碼農飛哥牛逼

2、字符串截取(字符串切片)

切片操作是訪問字符串的另一種方式,它可以訪問一定范圍內的元素,通過切片操作,可以生成一個新的字符串。切片操作的語法格式是:

sname[start : end : step]

各個參數的含義分別是:

  • sname: 表示字符串的名稱
  • start:表示切片的開始索引位置(包括該位置),此參數也可以不指定,不指定的情況下會默認為0,也就是從序列的開頭開始切片。
  • end:表示切片的結束索引位置(不包括該位置),如果不指定,則默認為序列的長度。
  • step: 表示步長,即在切片過程中,隔幾個存儲位置(包括當前位置)取一次元素,也就是說,如果step的值大於1,比如step為3時,則在切片取元素時,會隔2個位置去取下一個元素

還是舉個栗子說明下吧:

str1='好好學習,天天向上'
# 取出索引下標為7的值
print(str1[7])
# 從下標0開始取值,一直取到下標為7(不包括)的索引值
print(str1[0:7])
# 從下標1開始取值,一直取到下標為4(不包括)的索引值,因為step等於2,所以會隔1個元素取值
print(str1[1:4:2])
# 取出最後一個元素
print(str1[-1])
# 從下標-9開始取值,一直取到下標為-2(不包括)的索引值
print(str1[-9:-2])

運行的結果是:

向
好好學習,天天
好習
上
好好學習,天天

3、分割字符串

Python提供瞭split()方法用於分割字符串,split() 方法可以實現將一個字符串按照指定的分隔符切分成多個子串,這些子串會被保存到列表中(不包含分隔符),作為方法的返回值反饋回來。該方法的基本語法格式如下:

str.split(sep,maxsplit)

此方法中各部分參數的含義分別是:

  • str: 表示要進行分割的字符串
  • sep: 用於指定分隔符,可以包含多個字符,此參數默認為None,表示所有空字符,包括空格,換行符”\n”、制表符”\t”等
  • maxsplit: 可選參數,用於指定分割的次數,最後列表中子串的個數最多為maxsplit+1,如果不指定或者指定為-1,則表示分割次數沒有限制。

在 split 方法中,如果不指定 sep 參數,那麼也不能指定 maxsplit 參數。

舉例說明下:

str = 'https://feige.blog.csdn.net/'
print('不指定分割次數', str.split('.'))
print('指定分割次數為2次',str.split('.',2))

運行結果是:

不指定分割次數 ['https://feige', 'blog', 'csdn', 'net/']
指定分割次數為2次 ['https://feige', 'blog', 'csdn.net/']

4、合並字符串

合並字符串與split的作用剛剛相反,Python提供瞭join() 方法來將列表(或元組)中包含的多個字符串連接成一個字符串。其語法結構是:

newstr = str.join(iterable)

此方法各部分的參數含義是:

  • newstr: 表示合並後生成的新字符串
  • str: 用於指定合並時的分隔符
  • iterable: 做合並操作的源字符串數據,允許以列表、元組等形式提供。

依然是舉例說明:

list = ['碼農飛哥', '好好學習', '非常棒']
print('通過.來拼接', '.'.join(list))
print('通過-來拼接', '-'.join(list))

運行結果是:

通過.來拼接 碼農飛哥.好好學習.非常棒
通過-來拼接 碼農飛哥-好好學習-非常棒

5、統計字符串出現的次數

count()方法用於檢索指定字符串在另一字符串中出現的次數,如果檢索的字符串不存在,則返回0,否則返回出現的次數。其語法結構是:

str.count(sub[,start[,end]])

此方法各部分參數的含義是:

  • str: 表示原字符串
  • sub: 表示要檢索的字符串.
  • start: 指定檢索的起始位置,也就是從什麼位置開始檢測,如果不指定,默認從頭開始檢索。
  • end: 指定檢索的終止位置,如果不指定,則表示一直檢索到結尾

舉個例子說明:

str = 'https://feige.blog.csdn.net/'
print('統計.出現的次數', str.count('.'))
print('從1位置到倒數第五個位置統計.出現的次數', str.count('.', 1, -5))

運行結果是:

統計.出現的次數 3
從1位置到倒數第6個位置統計.出現的次數 2

6、檢測字符串是否包含某子串

Python提供find方法,用於檢索字符串中是否包含目標字符串,如果包含,則返回第一次出現該字符串的索引,反之,則返回-1。其語法結構是:

str.find(sub[,start[,end]])

此方法各參數的含義是:

  • str: 表示原字符串
  • sub: 表示要檢索的目標字符串
  • start: 表示開始檢索的起始位置,如果不指定,則默認從頭開始檢索
  • end: 表示結束檢索的結束位置,如果不指定,則默認一直檢索到結尾。

Python還提供瞭rfind()方法,與find()方法最大的不同在於,rfind()是從字符串右邊開始檢索。

依然是舉例說明:

str = '碼農飛哥'
print('檢索是否包含字符串"飛哥"', str.find('飛哥'))
print("檢索是否包含字符串'你好'", str.find('你好'))

運行結果是:

檢索是否包含字符串"飛哥" 2
檢索是否包含字符串'你好' -1

Python還提供瞭indext()方法檢測字符串中是否包含某子串,方法的參數與find方法相同,唯一不同之處在於當指定的字符串不存在時,index()方法會拋出異常。在此就不在贅述瞭。

7、字符串對齊方法

Python str提供瞭3種可用來進行文本對齊的方法,分別是ljust(),rjust()和center()方法

(1)ljust()用於向指定字符串的右側填充指定字符,從而達到左對齊文本的目的,其語法結構是

S.ljust(width[, fillchar])

此方法中各個參數的含義是:

  • S: 表示要進行填充的字符串
  • width: 表示包括S本身長度在內,字符串要占的總長度
  • fillchar: 作為可選參數,用來指定填充字符串時所用的字符,默認情況使用空格。

(2)rjust() 方法是向字符串的左側填充指定字符,從而達到右對齊文本的目的。
(3)center()方法用於讓文本居中,而不是左對齊或右對齊

舉個例子說明下:

str1 = 'https://feige.blog.csdn.net/'
str2 = 'https://www.baidu.com/'
print("通過-實現左對齊", str1.ljust(30, '-'))
print("通過-實現左對齊", str2.ljust(30, '-'))
print("通過-實現右對齊", str1.rjust(30, '-'))
print("通過-實現右對齊", str2.rjust(30, '-'))
print("通過-實現居中對齊", str1.center(30, '-'))
print("通過-實現居中對齊", str2.center(30, '-'))

運行結果是:

通過-實現左對齊 https://feige.blog.csdn.net/--
通過-實現左對齊 https://www.baidu.com/--------
通過-實現右對齊 --https://feige.blog.csdn.net/
通過-實現右對齊 --------https://www.baidu.com/
通過-實現居中對齊 -https://feige.blog.csdn.net/-
通過-實現居中對齊 ----https://www.baidu.com/----

8、檢索字符串是否以指定字符串開頭(startswith())

startswith()方法用於檢索字符串是否以指定字符串開頭,如果是返回True;反之返回False。其語法結構是:

str.startswith(sub[,start[,end]])

此方法各個參數的含義是:

  • str: 表示原字符串
  • sub: 要檢索的子串‘
  • start: 指定檢索開始的起始位置索引,如果不指定,則默認從頭開始檢索
  • end: 指定檢索的結束位置索引,如果不指定,則默認一直檢索到結束。

舉個栗子說明下:

str1 = 'https://feige.blog.csdn.net/'
print('是否是以https開頭', str1.startswith('https'))
print('是否是以feige開頭', str1.startswith('feige', 0, 20))

運行結果是:

是否是以https開頭 True
是否是以feige開頭 False

9、檢索字符串是否以指定字符串結尾(endswith())

endswith()方法用於檢索字符串是否以指定字符串結尾,如果是則返回True,反之則返回False。其語法結構是:

str.endswith(sub[,start[,end]])

此方法各個參數的含義與startswith方法相同,再此就不在贅述瞭。

10、字符串大小寫轉換(3種)函數及用法

Python中提供瞭3種方法用於字符串大小寫轉換

  • title()方法用於將字符串中每個單詞的首字母轉成大寫,其他字母全部轉為小寫。轉換完成後,此方法會返回轉換得到的字符串。如果字符串中沒有需要被轉換的字符,此方法會將字符串原封不動地返回。其語法結構是str.title()
  • lower()用於將字符串中的所有大寫字母轉換成小寫字母,轉換完成後,該方法會返回新得到的子串。如果字符串中原本就都是小寫字母,則該方法會返回原字符串。 其語法結構是str.lower()
  • upper()用於將字符串中的所有小寫字母轉換成大寫字母,如果轉換成功,則返回新字符串;反之,則返回原字符串。其語法結構是str.upper()。

舉例說明下吧:

str = 'feiGe勇敢飛'
print('首字母大寫', str.title())
print('全部小寫', str.lower())
print('全部大寫', str.upper())

運行結果是:

首字母大寫 Feige勇敢飛
全部小寫 feige勇敢飛
全部大寫 FEIGE勇敢飛

11、去除字符串中空格(刪除特殊字符)的3種方法

Python中提供瞭三種方法去除字符串中空格(刪除特殊字符)的3種方法,這裡的特殊字符,指的是指表符(\t)、回車符(\r),換行符(\n)等。

  • strip(): 刪除字符串前後(左右兩側)的空格或特殊字符
  • lstrip():刪除字符串前面(左邊)的空格或特殊字符
  • rstrip():刪除字符串後面(右邊)的空格或特殊字符

Python的str是不可變的,因此這三個方法隻是返回字符串前面或者後面空白被刪除之後的副本,並不會改變字符串本身

舉個例子說明下:

str = '\n碼農飛哥勇敢飛 '
print('去除前後空格(特殊字符串)', str.strip())
print('去除左邊空格(特殊字符串)', str.lstrip())
print('去除右邊空格(特殊字符串)', str.rstrip())

運行結果是:

去除前後空格(特殊字符串) 碼農飛哥勇敢飛
去除左邊空格(特殊字符串) 碼農飛哥勇敢飛 
去除右邊空格(特殊字符串) 
碼農飛哥勇敢飛

12、encode()和decode()方法:字符串編碼轉換

最早的字符串編碼是ASCll編碼,它僅僅對10個數字,26個大小寫英文字母以及一些特殊字符進行瞭編碼,ASCII碼最多隻能表示256個字符,每個字符隻需要占用1個字節。為瞭兼容各國的文字,相繼出現瞭GBK,GB2312,UTF-8編碼等,UTF-8是國際通用的編碼格式,它包含瞭全世界所有國傢需要用到的字符,其規定英文字符占用1個字節,中文字符占用3個字節。

  • encode() 方法為字符串類型(str)提供的方法,用於將 str 類型轉換成 bytes 類型,這個過程也稱為“編碼”。其語法結構是:str.encode([encoding=”utf-8″][,errors=”strict”])
  • 將bytes類型的二進制數據轉換成str類型。這個過程也稱為”解碼”,

其語法結構是:bytes.decode([encoding="utf-8"][,errors="strict"])

舉個例子說明下:

str = '碼農飛哥加油'
bytes = str.encode()
print('編碼', bytes)
print('解碼', bytes.decode())

運行結果是:

編碼 b'\xe7\xa0\x81\xe5\x86\x9c\xe9\xa3\x9e\xe5\x93\xa5\xe5\x8a\xa0\xe6\xb2\xb9'
解碼 碼農飛哥加油

默認的編碼格式是UTF-8,編碼和解碼的格式要相同,不然會解碼失敗。

13、序列化和反序列化

在實際工作中我們經常要將一個數據對象序列化成字符串,也會將一個字符串反序列化成一個數據對象。Python自帶的序列化模塊是json模塊。

  • json.dumps() 方法是將Python對象轉成字符串
  • json.loads()方法是將已編碼的 JSON 字符串解碼為 Python 對象

舉個例子說明下:

import json

dict = {'學號': 1001, 'name': "張三", 'score': [{'語文': 90, '數學': 100}]}
str = json.dumps(dict,ensure_ascii=False)
print('序列化成字符串', str, type(str))
dict2 = json.loads(str)
print('反序列化成對象', dict2, type(dict2))

運行結果是:

序列化成字符串 {"name": "張三", "score": [{"數學": 100, "語文": 90}], "學號": 1001} <class 'str'>
反序列化成對象 {'name': '張三', 'score': [{'數學': 100, '語文': 90}], '學號': 1001} <class 'dict'>

 到此這篇關於關於Python中字符串的各種操作的文章就介紹到這瞭,更多相關Python中字符串的各種操作內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: