Python刪除指定字符之前或之后所有內(nèi)容的方法
要刪除字符串中某個字符后的所有內(nèi)容:
- 使用 str.split() 方法在分隔符上拆分字符串。
- 訪問索引 0 處的列表元素以獲取分隔符之前的所有內(nèi)容。
- 或者,使用加法 + 運算符添加分隔符。
my_str = 'fql!jiyik!com' separator = '!' result = my_str.split(separator, 1)[0] print(result) ?# ??? 'fql'
我們使用 str.split() 方法刪除字符(示例中的?。┲蟮乃袃?nèi)容。
str.split() 方法使用定界符將字符串拆分為子字符串列表。
該方法采用以下 2 個參數(shù):
- separator 在每次出現(xiàn)分隔符時將字符串拆分為子字符串
- maxsplit 最多完成 maxsplit 拆分(可選)
如果在字符串中找不到分隔符,則返回僅包含 1 個元素的列表。
我們將 maxsplit 參數(shù)設置為 1,因為我們只需要拆分字符串一次。
該示例刪除字符串中該字符第一次出現(xiàn)后的所有內(nèi)容。
my_str = 'fql!jiyik!com' separator = '!' result_1 = my_str.split(separator, 1)[0] print(result_1) ?# ??? 'fql' # ??? ['fql', 'jiyik!com'] print(my_str.split(separator, 1))
刪除字符后的所有內(nèi)容,保留分隔符
請注意 ,分隔符不包含在字符串中。 如果需要包含它,請使用加法 (+) 運算符。
my_str = 'fql!jiyik!com' # ? 刪除字符后的所有內(nèi)容,保留分隔符 separator = '!' result = my_str.split(separator, 1)[0] + separator print(result) ?# ??? fql!
加法 + 運算符可用于在 Python 中連接字符串。
刪除最后一次出現(xiàn)的字符后的所有內(nèi)容
如果我們需要刪除字符串中最后一次出現(xiàn)該字符之后的所有內(nèi)容,請使用 str.rsplit() 方法。
my_str = 'fql!jiyik!com' separator = '!' # ? 刪除字符最后一次出現(xiàn)后的所有內(nèi)容 result = my_str.rsplit(separator, 1)[0] print(result) ?# ??? 'fql!jiyik'
除了從右側(cè)拆分外,rsplit() 的行為類似于 split()。
str.rsplit() 方法從右邊拆分字符串,將 maxsplit 設置為 1 時,它只拆分一次。
刪除最后一次出現(xiàn)后的所有內(nèi)容,保留分隔符
如果我們需要包括您拆分的字符,請使用加法運算符 (+)。
my_str = 'fql!jiyik!com' separator = '!' result = my_str.rsplit(separator, 1)[0] + separator print(result) ?# ??? 'fql!jiyik!'
使用 str.partition() 刪除字符后的所有內(nèi)容
我們還可以使用 str.partition() 方法刪除字符串中特定字符后的所有內(nèi)容。
my_str = 'fql!jiyik!com' separator = '!' result = my_str.partition(separator)[0] print(result) ?# ??? 'fql' result = ''.join(my_str.partition(separator)[0:2]) print(result) ?# ??? 'fql!'
str.partition 方法在第一次出現(xiàn)提供的分隔符時拆分字符串。
該方法返回一個包含 3 個元素的元組 - 分隔符之前的部分、分隔符和分隔符之后的部分。
my_str = 'fql!jiyik!com'
separator = '!'
# ??? ('fql', '!', 'jiyik!com')
print(my_str.partition(separator))如果在字符串中找不到分隔符,則該方法返回一個包含該字符串的元組,后跟 2 個空字符串。
如果我們需要在結(jié)果中包含分隔符,請使用 str.join() 方法連接第一個和第二個列表項。
my_str = 'fql!jiyik!com' separator = '!' result = ''.join(my_str.partition(separator)[0:2]) print(result) ?# ??? 'fql!'
str.join 方法將一個可迭代對象作為參數(shù)并返回一個字符串,該字符串是可迭代對象中字符串的串聯(lián)。
調(diào)用該方法的字符串用作元素之間的分隔符。
在 Python 中刪除字符串中字符之前的所有內(nèi)容
要刪除字符串中某個字符之前的所有內(nèi)容:
- 使用 str.find() 方法獲取字符的索引。
- 使用字符串切片并將起始索引設置為字符的索引。
- 新字符串將不包含前面的字符。
my_str = 'apple, banana'
result = my_str[my_str.find('b'):]
print(result) ?# ??? bananastr.find 方法返回字符串中提供的子字符串第一次出現(xiàn)的索引。
我們使用字符串切片來獲取原始字符串的一部分,該部分從字符的索引開始,一直持續(xù)到字符串的末尾。
請注意 ,如果在字符串中未找到子字符串,則 str.find() 方法返回 -1。
處理角色不存在的場景
我們可以處理 find() 方法在 if/else 語句中返回 -1 的情況。
my_str = 'apple, banana'
index = my_str.find('b')
print(index) # ??? 7
if index != -1:
? ? result = my_str[index:]
else:
? ? result = my_str
? ? # ??? alternatively raise an error
print(result) # ??? 'banana'這是提供的字符不在字符串中的情況的示例。
my_str = 'apple, banana'
index = my_str.find('z')
print(index) ?# ??? -1
if index != -1:
? ? result = my_str[index:]
else:
? ? result = my_str
? ? # ??? alternatively raise an error
print(result) ?# ??? 'apple, banana'我們的 else 語句將結(jié)果變量分配給整個字符串,但是,可以引發(fā)異常。
my_str = 'apple, banana'
index = my_str.find('z')
print(index) ?# ??? -1
if index != -1:
? ? result = my_str[index:]
else:
? ? # ??? this runs
? ? raise IndexError('provided character not in string')刪除最后一次出現(xiàn)的字符之前的所有內(nèi)容
如果我們需要刪除最后一次出現(xiàn)的字符之前的所有內(nèi)容,請使用 str.rfind() 方法。
my_str = 'apple,banana,bear'
result = my_str[my_str.rfind('b'):]
print(result) # ??? 'bear'str.rfind 方法返回字符串中找到提供的子字符串的最高索引。
如果字符串中不包含子字符串,則該方法返回 -1。
我們可以使用 if/else 語句處理字符不存在于字符串中的情況。
my_str = 'apple,banana,bear'
index = my_str.rfind('b')
if index != -1:
? ? result = my_str[index:]
else:
? ? result = my_str
print(result) ?# ??? 'bear'如果 else 塊運行,我們將結(jié)果變量設置為整個字符串。
或者,我們可以在 else 塊中引發(fā)錯誤,例如 raise IndexError('your message here')。
我們還可以使用 str.rsplit() 方法刪除最后一次出現(xiàn)的字符之前的所有內(nèi)容。
使用 rsplit() 刪除字符最后一次出現(xiàn)之前的所有內(nèi)容
要刪除最后一次出現(xiàn)的字符之前的所有內(nèi)容:
- 使用 str.rsplit() 方法從右邊拆分字符串。
- 訪問索引 1 處的列表項。
- 結(jié)果將是一個字符串,其中包含最后一次出現(xiàn)該字符之后的所有內(nèi)容。
my_str = 'example.com/articles/python'
result = my_str.rsplit('/', 1)[1]
print(result) ?# ??? 'python'
# ??? 如果你想在結(jié)果中包含這個字符
result_2 = '/' + my_str.rsplit('/', 1)[1]
print(result_2) ?# ??? '/python'
# ??? ['example.com/articles', 'python']
print(my_str.rsplit('/', 1))我們使用 str.rsplit() 方法刪除最后一個字符出現(xiàn)之前的所有內(nèi)容。
str.rsplit 方法使用提供的分隔符作為分隔符字符串返回字符串中的單詞列表。
my_str = 'one two three'
print(my_str.rsplit(' ')) ?# ??? ['one', 'two', 'three']
print(my_str.rsplit(' ', 1)) ?# ??? ['one two', 'three']該方法采用以下 2 個參數(shù):
- separator 在每次出現(xiàn)分隔符時將字符串拆分為子字符串
- maxsplit 最多做maxsplit的分裂,最右邊的(可選)
除了從右側(cè)拆分外,rsplit() 的行為類似于 split()。
請注意 ,我們?yōu)?maxsplit 參數(shù)提供了值 1,因為我們只想從右側(cè)拆分字符串一次。
my_str = 'example.com/articles/python'
result = my_str.rsplit('/', 1)[1]
print(result) ?# ??? 'python'
# ??? ['example.com/articles', 'python']
print(my_str.rsplit('/', 1))最后一步是訪問索引 1 處的列表元素,以獲取包含指定字符最后一次出現(xiàn)之后的所有內(nèi)容的字符串。
如果要在結(jié)果中包含該字符,請使用加法 + 運算符。
my_str = 'example.com/articles/python'
result = '/' + my_str.rsplit('/', 1)[1]
print(result) ?# ??? '/python'使用 rpartition() 刪除字符最后一次出現(xiàn)之前的所有內(nèi)容
或者,我們可以使用 str.rpartition() 方法。
my_str = 'example.com/articles/python'
result = my_str.rpartition('/')[2]
print(result) ?# ??? 'python'
# ??? ('example.com/articles', '/', 'python')
print(my_str.rpartition('/'))str.rpartition 方法在提供的分隔符的最后一次出現(xiàn)處拆分字符串。
該方法返回一個包含 3 個元素的元組 - 分隔符之前的部分、分隔符和分隔符之后的部分。
如果在字符串中找不到分隔符,則該方法返回一個包含兩個空字符串的元組,后跟字符串本身。
如果需要在結(jié)果中包含分隔符,請使用 str.join() 方法連接第二個和第三個列表項。
my_str = 'example.com/articles/python'
result = ''.join(my_str.rpartition('/')[1:])
print(result) ?# ??? '/python'str.join 方法將一個可迭代對象作為參數(shù)并返回一個字符串,該字符串是可迭代對象中字符串的串聯(lián)。
調(diào)用該方法的字符串用作元素之間的分隔符。
到此這篇關于Python刪除指定字符之前或之后所有內(nèi)容的方法的文章就介紹到這了,更多相關Python刪除指定字符內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python使用Plotly繪制常見5種動態(tài)交互式圖表
Plotly是一個非常強大的開源數(shù)據(jù)可視化框架,它通過構建基于 HTML 的交互式圖表來顯示信息,可創(chuàng)建各種形式的精美圖表。本文將用Plotly庫繪制常見的五種動態(tài)交互式圖表,感興趣的可以學習一下2022-03-03
python人工智能算法之人工神經(jīng)網(wǎng)絡
這篇文章主要為大家介紹了python人工智能算法之人工神經(jīng)網(wǎng)絡示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03
OpenCV python sklearn隨機超參數(shù)搜索的實現(xiàn)
這篇文章主要介紹了OpenCV python sklearn隨機超參數(shù)搜索的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01
Python Socket多線程并發(fā)原理及實現(xiàn)
這篇文章主要介紹了Python Socket多線程并發(fā)原理及實現(xiàn),幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-12-12
Python使用內(nèi)置函數(shù)setattr設置對象的屬性值
這篇文章主要介紹了Python使用內(nèi)置函數(shù)setattr設置對象的屬性值,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-10-10

