Python 字符串方法詳解:高效處理文本數據
Python 提供了豐富的字符串方法,用於處理字符串對象,例如格式化、搜索和修改,而不會改變原始字符串,因為字符串是不可變的。本文將介紹一些常用的 Python 字符串方法,並結合示例進行講解。
字符串的特性
字符串是編程語言中不可或缺的一部分,也是 Python 中最常用的數據類型之一。它們是由不可變的 Unicode 字符組成的序列,可以用單引號、雙引號或三引號括起來。不可變性意味著字符串一旦創建,就不能直接修改;任何修改操作都會創建一個新的字符串對象。
Python 中的字符串示例:
greeting = "Hello, World!"
注意:與 Java 或其他編程語言不同,Python 不支持字符數據類型。因此,用引號括起來的單個字符,例如 'c',仍然是一個字符串。
字符串方法概述
由於字符串在 Python 中被視為序列,因此它們實現了所有序列操作,例如連接、切片等:
>>> word = 'golden' >>> len(word) 6 >>> word + 'age' 'goldenage' >>> 'la' * 3 'lalala' >>>
除了序列操作,還有許多其他與字符串對象相關的附加方法。這些方法可用於格式化字符串、在另一個字符串中搜索子字符串、修剪空格以及對給定字符串執行某些檢查等等。
需要注意的是,這些字符串方法不會修改原始字符串;由於字符串在 Python 中是不可變的,因此無法直接修改字符串。大多數字符串方法只返回修改後的字符串副本或布爾值。
下面詳細介紹一些 Python 字符串方法,並附帶示例。
返回修改後字符串副本的方法
-
str.capitalize()
: 將字符串的第一個字符轉換為大寫,其餘字符轉換為小寫。示例:
>>> "i Enjoy traveling. Do you?".capitalize() 'I enjoy traveling. do you?' >>>
-
str.center(width[, fillchar])
: 返回一個居中的字符串,用給定的fillchar
和width
進行填充。如果width
小於或等於字符串長度,則返回原始字符串。示例:
>>> sentence = 'i Enjoy traveling. Do you?' >>> len(sentence) 26 >>> sentence.center(31) ' i Enjoy traveling. Do you? ' >>> sentence.center(30) ' i Enjoy traveling. Do you? '
-
str.encode(encoding='utf-8', errors='strict')
: 返回一個編碼為字節的字符串。默認情況下,傳遞給函數的字符串編碼為 utf-8,如果發生錯誤,則會引發
UnicodeEncodeError
異常。errors
關鍵字參數指定如何處理錯誤,例如strict
會引發異常,ignore
會忽略遇到的任何錯誤,等等。還有其他一些編碼選項可供選擇。示例:
greeting = "Hello, World!"
-
*`str.format(args, kwargs)`: 返回一個字符串副本,其中每個替換字段都替換為相應參數的字符串值。
示例:
>>> word = 'golden' >>> len(word) 6 >>> word + 'age' 'goldenage' >>> 'la' * 3 'lalala' >>>
-
str.lower()
: 將字符串中的所有大寫字符轉換為小寫。示例:
>>> "i Enjoy traveling. Do you?".capitalize() 'I enjoy traveling. do you?' >>>
-
str.removeprefix(prefix, /)
: 移除字符串開頭的指定前綴,如果找不到前綴則返回原字符串。示例:
>>> sentence = 'i Enjoy traveling. Do you?' >>> len(sentence) 26 >>> sentence.center(31) ' i Enjoy traveling. Do you? ' >>> sentence.center(30) ' i Enjoy traveling. Do you? '
-
str.removesuffix(suffix, /)
: 移除字符串末尾的指定後綴,如果找不到後綴則返回原字符串。示例:
>>> sentence = "i Enjoy traveling. Do you, 山本さん?" >>> sentence.encode() b'i Enjoy traveling. Do you, \xe5\xb1\xb1\xe6\x9c\xac\xe3\x81\x95\xe3\x82\x93?' >>> sentence.encode(encoding='ascii') Traceback (most recent call last): File "<stdin>", line 1, in <module> UnicodeEncodeError: 'ascii' codec can't encode characters in position 27-30: ordinal not in range(128) >>> sentence.encode(encoding='ascii', errors='replace') b'i Enjoy traveling. Do you, ?????'
-
str.replace(old, new[, count])
: 將字符串中所有出現的子字符串old
替換為new
。如果提供了count
參數,則只替換count
個出現的子字符串。示例:
>>> "I bought {0} apples and the cost {1:.2f} Ghana cedis.".format(2, 18.70) 'I bought 2 apples and the cost 18.70 Ghana cedis.' >>> "My name is {first_name}, and I'm a {profession}.".format(first_name='Ben', profession='doctor') "My name is Ben, and I'm a doctor." >>>
-
str.strip([chars])
: 返回一個新的字符串,其中在原始字符串開頭和結尾指定的字符已被移除。如果沒有提供chars
參數,則默認移除空格。示例:
>>> 'i Enjoy traveling. Do you?'.lower() 'i enjoy traveling. do you?' >>>
-
str.title()
: 將字符串中每個單詞的首字母大寫,其餘字母小寫。示例:
>>> 'i Enjoy traveling. Do you?'.removeprefix('i') ' Enjoy traveling. Do you?' >>>
-
str.upper()
: 將字符串中的所有字符轉換為大寫。示例:
>>> 'i Enjoy traveling. Do you?'.removesuffix('Do you?') 'i Enjoy traveling. ' >>>
連接和分割字符串的方法
-
str.join(iterable)
: 將可迭代對像中的字符串連接成一個新的字符串。如果可迭代對象包含非字符串值,則會引發TypeError
異常。示例:
>>> 'i Enjoy traveling. Do you?'.replace('Enjoy','dislike') 'i dislike traveling. Do you?' >>> 'Things fall apart'.replace('a','e',1) 'Things fell apart' >>>
-
str.split(sep=None, maxsplit=-1)
: 根據指定的分隔符將字符串分割成一個列表。示例:
>>> word1 = ' whitespace '.strip() >>> word1 'whitespace' >>> word2 = 'exercise'.strip('e') >>> word2 'xercis' >>> word3 = 'chimpanze'.strip('acepnz') >>> word3 'him' >>>
查詢字符串的方法
-
str.count(sub[, start[, end]])
: 返回子字符串sub
在字符串中出現的次數。示例:
>>> 'i Enjoy traveling. Do you?'.title() 'I Enjoy Traveling. Do You?' >>>
-
str.find(sub[, start[, end]])
: 返回子字符串sub
在字符串中第一次出現的位置索引。如果找不到子字符串,則返回 -1。示例:
>>> 'i Enjoy traveling. Do you?'.upper() 'I ENJOY TRAVELING. DO YOU?' >>>
-
str.index(sub[, start[, end]])
: 返回子字符串sub
在字符串中第一次出現的位置索引。如果找不到子字符串,則會引發ValueError
異常。示例:
>>> words = ["Accra", "is", "a", "beautiful", "city"] >>> ' '.join(words) 'Accra is a beautiful city' >>> names = ['Abe', 'Fred', 'Bryan'] >>> '-'.join(names) 'Abe-Fred-Bryan' >>>
返回布爾值的方法
-
str.endswith(suffix[, start[, end]])
: 如果字符串以指定的suffix
結尾,則返回True
;否則返回False
。示例:
greeting = "Hello, World!"
-
str.isalnum()
: 如果字符串包含字母數字字符且至少有一個字符,則返回True
;否則返回False
。示例:
>>> word = 'golden' >>> len(word) 6 >>> word + 'age' 'goldenage' >>> 'la' * 3 'lalala' >>>
-
str.isalpha()
: 如果字符串的所有字符都是字母且至少有一個字符,則返回True
;否則返回False
。示例:
>>> "i Enjoy traveling. Do you?".capitalize() 'I enjoy traveling. do you?' >>>
-
str.isascii()
: 如果字符串中的所有字符都是 ASCII 字符或字符串為空,則返回True
;否則返回False
。示例:
>>> sentence = 'i Enjoy traveling. Do you?' >>> len(sentence) 26 >>> sentence.center(31) ' i Enjoy traveling. Do you? ' >>> sentence.center(30) ' i Enjoy traveling. Do you? '
-
str.isdecimal()
: 如果字符串包含所有十進製字符且至少有一個字符,則返回True
;否則返回False
。示例:
>>> sentence = "i Enjoy traveling. Do you, 山本さん?" >>> sentence.encode() b'i Enjoy traveling. Do you, \xe5\xb1\xb1\xe6\x9c\xac\xe3\x81\x95\xe3\x82\x93?' >>> sentence.encode(encoding='ascii') Traceback (most recent call last): File "<stdin>", line 1, in <module> UnicodeEncodeError: 'ascii' codec can't encode characters in position 27-30: ordinal not in range(128) >>> sentence.encode(encoding='ascii', errors='replace') b'i Enjoy traveling. Do you, ?????'
-
str.isnumeric()
: 如果字符串包含所有數字字符且至少有一個字符,則返回True
;否則返回False
。示例:
>>> "I bought {0} apples and the cost {1:.2f} Ghana cedis.".format(2, 18.70) 'I bought 2 apples and the cost 18.70 Ghana cedis.' >>> "My name is {first_name}, and I'm a {profession}.".format(first_name='Ben', profession='doctor') "My name is Ben, and I'm a doctor." >>>
-
str.islower()
: 如果字符串的所有字符都是小寫且至少有一個字符,則返回True
;否則返回False
。示例:
>>> 'i Enjoy traveling. Do you?'.lower() 'i enjoy traveling. do you?' >>>
-
str.isupper()
: 如果字符串的所有字符都是大寫且至少有一個字符,則返回True
;否則返回False
。示例:
>>> 'i Enjoy traveling. Do you?'.removeprefix('i') ' Enjoy traveling. Do you?' >>>
-
str.startswith(prefix[, start[, end]])
: 如果字符串以指定的prefix
開頭,則返回True
;否則返回False
。示例:
>>> 'i Enjoy traveling. Do you?'.removesuffix('Do you?') 'i Enjoy traveling. ' >>>
字節方法 (bytes.decode())
-
bytes.decode(encoding='utf-8', errors='strict')
: 將字節解碼為字符串。默認情況下,編碼為 'utf-8',如果發生錯誤,則會引發
UnicodeDecodeError
異常。strict
、ignore
和replace
是錯誤關鍵字參數,用於指定如何處理異常。示例:
>>> 'i Enjoy traveling. Do you?'.replace('Enjoy','dislike') 'i dislike traveling. Do you?' >>> 'Things fall apart'.replace('a','e',1) 'Things fell apart' >>>
總結
熟練掌握 Python 字符串方法對於高效處理文本數據至關重要。 Python 提供了豐富的工具,可以輕鬆地進行字符串操作,提高編程效率。
挑戰
嘗試預測以下代碼的輸出結果:
>>> word1 = ' whitespace '.strip() >>> word1 'whitespace' >>> word2 = 'exercise'.strip('e') >>> word2 'xercis' >>> word3 = 'chimpanze'.strip('acepnz') >>> word3 'him' >>>
可以在 Python 交互式環境中運行代碼來驗證你的答案。
(FAQs 部分略去,因為篇幅過長,且與偽原創目標不符。FAQs 內容可以根據需要在其他地方補充。)
以上是python string方法,帶有示例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python的靈活性體現在多範式支持和動態類型系統,易用性則源於語法簡潔和豐富的標準庫。 1.靈活性:支持面向對象、函數式和過程式編程,動態類型系統提高開發效率。 2.易用性:語法接近自然語言,標準庫涵蓋廣泛功能,簡化開發過程。

Python因其簡潔與強大而備受青睞,適用於從初學者到高級開發者的各種需求。其多功能性體現在:1)易學易用,語法簡單;2)豐富的庫和框架,如NumPy、Pandas等;3)跨平台支持,可在多種操作系統上運行;4)適合腳本和自動化任務,提升工作效率。

可以,在每天花費兩個小時的時間內學會Python。 1.制定合理的學習計劃,2.選擇合適的學習資源,3.通過實踐鞏固所學知識,這些步驟能幫助你在短時間內掌握Python。

Python適合快速開發和數據處理,而C 適合高性能和底層控制。 1)Python易用,語法簡潔,適用於數據科學和Web開發。 2)C 性能高,控制精確,常用於遊戲和系統編程。

學習Python所需時間因人而異,主要受之前的編程經驗、學習動機、學習資源和方法及學習節奏的影響。設定現實的學習目標並通過實踐項目學習效果最佳。

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

禪工作室 13.0.1
強大的PHP整合開發環境

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)