您好,登錄后才能下訂單哦!
這篇文章主要介紹了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))
請(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 中連接字符串。
如果我們需要?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í),它只拆分一次。
如果我們需要包括您拆分的字符,請(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)容。
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)用該方法的字符串用作元素之間的分隔符。
要?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。
我們可以處理 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')
如果我們需要?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)容。
要?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'
或者,我們可以使用 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è)資訊頻道。
免責(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)容。