午夜视频在线网站,日韩视频精品在线,中文字幕精品一区二区三区在线,在线播放精品,1024你懂我懂的旧版人,欧美日韩一级黄色片,一区二区三区在线观看视频

分享

31個(gè)必備的Python字符串方法,建議收藏!

 zZ華 2022-01-16

大家好,我是小F。

字符串是Python中基本的數(shù)據(jù)類型,幾乎在每個(gè)Python程序中都會(huì)使用到它。

今天,小F就帶大家學(xué)習(xí)一下31個(gè)最重要的內(nèi)置字符串方法。

希望大家能從中找到對(duì)自己有幫助的技巧。

▍1、Slicing

slicing切片,按照一定條件從列表或者元組中取出部分元素(比如特定范圍、索引、分割值)

s = '   hello   '
s = s[:]

print(s)
#    hello


s = '   hello   '
s = s[3:8]

print(s)
# hello

▍2、strip()

strip()方法用于移除字符串頭尾指定的字符(默認(rèn)為空格或換行符)或字符序列。

s = '   hello   '.strip()

print(s)
# hello


s = '###hello###'.strip()

print(s)
# ###hello###

在使用strip()方法時(shí),默認(rèn)去除空格或換行符,所以#號(hào)并沒有去除。

可以給strip()方法添加指定字符,如下所示。

s = '###hello###'.strip('#')

print(s)
# hello

此外當(dāng)指定內(nèi)容不在頭尾處時(shí),并不會(huì)被去除。

s = ' \n \t hello\n'.strip('\n')

print(s)
#
#      hello


s = '\n \t hello\n'.strip('\n')

print(s)
#      hello

第一個(gè)\n前有個(gè)空格,所以只會(huì)去取尾部的換行符。

最后strip()方法的參數(shù)是剝離其值的所有組合,這個(gè)可以看下面這個(gè)案例。

s = 'www.baidu.com'.strip('cmow.')

print(s)
# baidu

最外層的首字符和尾字符參數(shù)值將從字符串中剝離。字符從前端移除,直到到達(dá)一個(gè)不包含在字符集中的字符串字符為止。

在尾部也會(huì)發(fā)生類似的動(dòng)作。

▍3、lstrip()

移除字符左側(cè)指定的字符(默認(rèn)為空格或換行符)或字符序列。

s = '   hello   '.lstrip()

print(s)
# hello

同樣的,可以移除左側(cè)所有包含在字符集中的字符串。

s = 'Arthur: three!'.lstrip('Arthur: ')

print(s)
# ee!

▍4、rstrip()

移除字符串右側(cè)指定的字符(默認(rèn)為空格或換行符)或字符序列。

s = '   hello   '.rstrip()

print(s)
#    hello

▍5、removeprefix()

Python3.9中移除前綴的函數(shù)。

# python 3.9
s = 'Arthur: three!'.removeprefix('Arthur: ')

print(s)
# three!

和strip()相比,并不會(huì)把集中的字符串進(jìn)行逐個(gè)匹配。

▍6、removesuffix()

Python3.9中移除后綴的函數(shù)。

s = 'HelloPython'.removesuffix('Python')

print(s)
# Hello

▍7、replace()

把字符串中的內(nèi)容替換成指定的內(nèi)容。

s = 'string methods in python'.replace(' ''-')

print(s)
# string-methods-in-python


s = 'string methods in python'.replace(' ''')

print(s)
# stringmethodsinpython

▍8、re.sub()

re是正則的表達(dá)式,sub是substitute表示替換。

re.sub則是相對(duì)復(fù)雜點(diǎn)的替換。

import re
s = 'string    methods in python'
s2 = s.replace(' ''-')
print(s2)
# string----methods-in-python


s = 'string    methods in python'
s2 = re.sub('\s+''-', s)
print(s2)
# string-methods-in-python

和replace()做對(duì)比,使用re.sub()進(jìn)行替換操作,確實(shí)更高級(jí)點(diǎn)。

▍9、split()

對(duì)字符串做分隔處理,最終的結(jié)果是一個(gè)列表。

s = 'string methods in python'.split()

print(s)
# ['string', 'methods', 'in', 'python']

當(dāng)不指定分隔符時(shí),默認(rèn)按空格分隔。

s = 'string methods in python'.split(',')

print(s)
# ['string methods in python']

此外,還可以指定字符串的分隔次數(shù)。

s = 'string methods in python'.split(' ', maxsplit=1)

print(s)
# ['string', 'methods in python']

▍10、rsplit()

從右側(cè)開始對(duì)字符串進(jìn)行分隔。

s = 'string methods in python'.rsplit(' ', maxsplit=1)

print(s)
# ['string methods in', 'python']

▍11、join()

string.join(seq)。以string作為分隔符,將seq中所有的元素(的字符串表示)合并為一個(gè)新的字符串。

list_of_strings = ['string''methods''in''python']
s = '-'.join(list_of_strings)

print(s)
# string-methods-in-python


list_of_strings = ['string''methods''in''python']
s = ' '.join(list_of_strings)

print(s)
# string methods in python

▍12、upper()

將字符串中的字母,全部轉(zhuǎn)換為大寫。

s = 'simple is better than complex'.upper()

print(s)
# SIMPLE IS BETTER THAN COMPLEX

▍13、lower()

將字符串中的字母,全部轉(zhuǎn)換為小寫。

s = 'SIMPLE IS BETTER THAN COMPLEX'.lower()

print(s)
# simple is better than complex

▍14、capitalize()

將字符串中的首個(gè)字母轉(zhuǎn)換為大寫。

s = 'simple is better than complex'.capitalize()

print(s)
# Simple is better than complex

▍15、islower()

判斷字符串中的所有字母是否都為小寫,是則返回True,否則返回False。

print('SIMPLE IS BETTER THAN COMPLEX'.islower()) # False

print('simple is better than complex'.islower()) # True

▍16、isupper()

判斷字符串中的所有字母是否都為大寫,是則返回True,否則返回False。

print('SIMPLE IS BETTER THAN COMPLEX'.isupper()) # True

print('SIMPLE IS BETTER THAN complex'.isupper()) # False

▍17、isalpha()

如果字符串至少有一個(gè)字符并且所有字符都是字母,則返回 True,否則返回 False。

s = 'python'
print(s.isalpha())
# True

s = '123'
print(s.isalpha())
# False

s = 'python123'
print(s.isalpha())
# False

s = 'python-123'
print(s.isalpha())
# False

▍18、isnumeric()

如果字符串中只包含數(shù)字字符,則返回 True,否則返回 False。

s = 'python'
print(s.isnumeric())
# False

s = '123'
print(s.isnumeric())
# True

s = 'python123'
print(s.isnumeric())
# False

s = 'python-123'
print(s.isnumeric())
# False

▍19、isalnum()

如果字符串中至少有一個(gè)字符并且所有字符都是字母或數(shù)字,則返回True,否則返回 False。

s = 'python'
print(s.isalnum())
# True

s = '123'
print(s.isalnum())
# True

s = 'python123'
print(s.isalnum())
# True

s = 'python-123'
print(s.isalnum())
# False

▍20、count()

返回指定內(nèi)容在字符串中出現(xiàn)的次數(shù)。

n = 'hello world'.count('o')
print(n)
# 2

n = 'hello world'.count('oo')
print(n)
# 0

▍21、find()

檢測(cè)指定內(nèi)容是否包含在字符串中,如果是返回開始的索引值,否則返回-1。

s = 'Machine Learning'
idx = s.find('a')

print(idx)
print(s[idx:])
# 1
# achine Learning

s = 'Machine Learning'
idx = s.find('aa')

print(idx)
print(s[idx:])
# -1
# g

此外,還可以指定開始的范圍。

s = 'Machine Learning'
idx = s.find('a'2)

print(idx)
print(s[idx:])
# 10
# arning

▍22、rfind()

類似于find()函數(shù),返回字符串最后一次出現(xiàn)的位置,如果沒有匹配項(xiàng)則返回 -1。

s = 'Machine Learning'
idx = s.rfind('a')

print(idx)
print(s[idx:])
# 10
# arning

▍23、startswith()

檢查字符串是否是以指定內(nèi)容開頭,是則返回 True,否則返回 False。

print('Patrick'.startswith('P'))

# True

▍24、endswith()

檢查字符串是否是以指定內(nèi)容結(jié)束,是則返回 True,否則返回 False。

print('Patrick'.endswith('ck'))

# True

▍25、partition()

string.partition(str),有點(diǎn)像find()和split()的結(jié)合體。

從str出現(xiàn)的第一個(gè)位置起,把字符串string分成一個(gè)3 元素的元組(string_pre_str,str,string_post_str),如果string中不包含str則 string_pre_str==string。

s = 'Python is awesome!'
parts = s.partition('is')
print(parts)
# ('Python ', 'is', ' awesome!')

s = 'Python is awesome!'
parts = s.partition('was')
print(parts)
# ('Python is awesome!', '', '')

▍26、center()

返回一個(gè)原字符串居中,并使用空格填充至長(zhǎng)度width的新字符串。

s = 'Python is awesome!'
s = s.center(30'-')

print(s)
# ------Python is awesome!------

▍27、ljust()

返回一個(gè)原字符串左對(duì)齊,并使用空格填充至長(zhǎng)度width的新字符串。


s = 'Python is awesome!'
s = s.ljust(30'-')

print(s)
# Python is awesome!------------

▍28、rjust()

返回一個(gè)原字符串右對(duì)齊,并使用空格填充至長(zhǎng)度width的新字符串。

s = 'Python is awesome!'
s = s.rjust(30'-')

print(s)
# ------------Python is awesome!

▍29、f-Strings

f-string是格式化字符串的新語法。

與其他格式化方式相比,它們不僅更易讀,更簡(jiǎn)潔,不易出錯(cuò),而且速度更快!

num = 1
language = 'Python'
s = f'{language} is the number {num} in programming!'

print(s)
# Python is the number 1 in programming!


num = 1
language = 'Python'
s = f'{language} is the number {num*8} in programming!'

print(s)
# Python is the number 8 in programming!

▍30、swapcase()

翻轉(zhuǎn)字符串中的字母大小寫。

s = 'HELLO world'
s = s.swapcase()

print(s)
# hello WORLD

▍31、zfill()


string.zfill(width)。

返回長(zhǎng)度為width的字符串,原字符串string右對(duì)齊,前面填充0。

s = '42'.zfill(5)
print(s)
# 00042

s = '-42'.zfill(5)
print(s)
# -0042

s = '+42'.zfill(5)
print(s)
# +0042


萬水千山總是情,點(diǎn)個(gè) ?? 行不行

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多