溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python如何刪除指定字符之前或之后所有內(nèi)容

發(fā)布時(shí)間:2023-05-04 09:44:30 來(lái)源:億速云 閱讀:116 作者:zzz 欄目:編程語(yǔ)言

這篇文章主要介紹了Python如何刪除指定字符之前或之后所有內(nèi)容的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Python如何刪除指定字符之前或之后所有內(nèi)容文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

my_str = 'fql!jiyik!com'

separator = '!'

result = my_str.split(separator, 1)[0]
print(result)  # ????? 'fql'

我們使用 str.split() 方法刪除字符(示例中的?。┲蟮乃袃?nèi)容。

str.split() 方法使用定界符將字符串拆分為子字符串列表。

該方法采用以下 2 個(gè)參數(shù):

  • separator 在每次出現(xiàn)分隔符時(shí)將字符串拆分為子字符串

  • maxsplit 最多完成 maxsplit 拆分(可選)

如果在字符串中找不到分隔符,則返回僅包含 1 個(gè)元素的列表。

我們將 maxsplit 參數(shù)設(shè)置為 1,因?yàn)槲覀冎恍枰鸱肿址淮巍?/p>

該示例刪除字符串中該字符第一次出現(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)容,保留分隔符

請(qǐng)注意 ,分隔符不包含在字符串中。 如果需要包含它,請(qǐng)使用加法 (+) 運(yùn)算符。

my_str = 'fql!jiyik!com'

# ? 刪除字符后的所有內(nèi)容,保留分隔符
separator = '!'

result = my_str.split(separator, 1)[0] + separator
print(result)  # ????? fql!

加法 + 運(yùn)算符可用于在 Python 中連接字符串。

刪除最后一次出現(xiàn)的字符后的所有內(nèi)容

如果我們需要?jiǎng)h除字符串中最后一次出現(xiàn)該字符之后的所有內(nèi)容,請(qǐng)使用 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() 的行為類(lèi)似于 split()。

str.rsplit() 方法從右邊拆分字符串,將 maxsplit 設(shè)置為 1 時(shí),它只拆分一次。

刪除最后一次出現(xiàn)后的所有內(nèi)容,保留分隔符

如果我們需要包括您拆分的字符,請(qǐng)使用加法運(yùn)算符 (+)。

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)提供的分隔符時(shí)拆分字符串。

該方法返回一個(gè)包含 3 個(gè)元素的元組 - 分隔符之前的部分、分隔符和分隔符之后的部分。

my_str = 'fql!jiyik!com'
separator = '!'

# ????? ('fql', '!', 'jiyik!com')
print(my_str.partition(separator))

如果在字符串中找不到分隔符,則該方法返回一個(gè)包含該字符串的元組,后跟 2 個(gè)空字符串。

如果我們需要在結(jié)果中包含分隔符,請(qǐng)使用 str.join() 方法連接第一個(gè)和第二個(gè)列表項(xiàng)。

my_str = 'fql!jiyik!com'
separator = '!'

result = ''.join(my_str.partition(separator)[0:2])
print(result)  # ????? 'fql!'

str.join 方法將一個(gè)可迭代對(duì)象作為參數(shù)并返回一個(gè)字符串,該字符串是可迭代對(duì)象中字符串的串聯(lián)。

調(diào)用該方法的字符串用作元素之間的分隔符。

在 Python 中刪除字符串中字符之前的所有內(nèi)容

要?jiǎng)h除字符串中某個(gè)字符之前的所有內(nèi)容:

  • 使用 str.find() 方法獲取字符的索引。

  • 使用字符串切片并將起始索引設(shè)置為字符的索引。

  • 新字符串將不包含前面的字符。

my_str = 'apple, banana'

result = my_str[my_str.find('b'):]
print(result)  # ????? banana

str.find 方法返回字符串中提供的子字符串第一次出現(xiàn)的索引。

我們使用字符串切片來(lái)獲取原始字符串的一部分,該部分從字符的索引開(kāi)始,一直持續(xù)到字符串的末尾。

請(qǐng)注意 ,如果在字符串中未找到子字符串,則 str.find() 方法返回 -1。

處理角色不存在的場(chǎng)景

我們可以處理 find() 方法在 if/else 語(yǔ)句中返回 -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 語(yǔ)句將結(jié)果變量分配給整個(gè)字符串,但是,可以引發(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)容

如果我們需要?jiǎng)h除最后一次出現(xiàn)的字符之前的所有內(nèi)容,請(qǐng)使用 str.rfind() 方法。

my_str = 'apple,banana,bear'

result = my_str[my_str.rfind('b'):]

print(result) # ????? 'bear'

str.rfind 方法返回字符串中找到提供的子字符串的最高索引。

如果字符串中不包含子字符串,則該方法返回 -1。

我們可以使用 if/else 語(yǔ)句處理字符不存在于字符串中的情況。

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 塊運(yùn)行,我們將結(jié)果變量設(shè)置為整個(gè)字符串。

或者,我們可以在 else 塊中引發(fā)錯(cuò)誤,例如 raise IndexError('your message here')。

我們還可以使用 str.rsplit() 方法刪除最后一次出現(xiàn)的字符之前的所有內(nèi)容。

使用 rsplit() 刪除字符最后一次出現(xiàn)之前的所有內(nèi)容

要?jiǎng)h除最后一次出現(xiàn)的字符之前的所有內(nèi)容:

  • 使用 str.rsplit() 方法從右邊拆分字符串。

  • 訪問(wèn)索引 1 處的列表項(xiàng)。

  • 結(jié)果將是一個(gè)字符串,其中包含最后一次出現(xiàn)該字符之后的所有內(nèi)容。

my_str = 'example.com/articles/python'

result = my_str.rsplit('/', 1)[1]
print(result)  # ????? 'python'

# ????? 如果你想在結(jié)果中包含這個(gè)字符
result_2 = '/' + my_str.rsplit('/', 1)[1]
print(result_2)  # ????? '/python'

# ????? ['example.com/articles', 'python']
print(my_str.rsplit('/', 1))

我們使用 str.rsplit() 方法刪除最后一個(gè)字符出現(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 個(gè)參數(shù):

  • separator 在每次出現(xiàn)分隔符時(shí)將字符串拆分為子字符串

  • maxsplit 最多做maxsplit的分裂,最右邊的(可選)

除了從右側(cè)拆分外,rsplit() 的行為類(lèi)似于 split()。

請(qǐng)注意 ,我們?yōu)?maxsplit 參數(shù)提供了值 1,因?yàn)槲覀冎幌霃挠覀?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))

最后一步是訪問(wèn)索引 1 處的列表元素,以獲取包含指定字符最后一次出現(xiàn)之后的所有內(nèi)容的字符串。

如果要在結(jié)果中包含該字符,請(qǐng)使用加法 + 運(yùn)算符。

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)處拆分字符串。

該方法返回一個(gè)包含 3 個(gè)元素的元組 - 分隔符之前的部分、分隔符和分隔符之后的部分。

如果在字符串中找不到分隔符,則該方法返回一個(gè)包含兩個(gè)空字符串的元組,后跟字符串本身。

如果需要在結(jié)果中包含分隔符,請(qǐng)使用 str.join() 方法連接第二個(gè)和第三個(gè)列表項(xiàng)。

my_str = 'example.com/articles/python'

result = ''.join(my_str.rpartition('/')[1:])
print(result)  # ????? '/python'

str.join 方法將一個(gè)可迭代對(duì)象作為參數(shù)并返回一個(gè)字符串,該字符串是可迭代對(duì)象中字符串的串聯(lián)。

調(diào)用該方法的字符串用作元素之間的分隔符。

關(guān)于“Python如何刪除指定字符之前或之后所有內(nèi)容”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Python如何刪除指定字符之前或之后所有內(nèi)容”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI