欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python中常用的8種字符串操作方法

 更新時(shí)間:2019年05月06日 08:46:12   作者:sf_wangchong  
這篇文章主要介紹了Python中常用的8種字符串操作方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

拼接字符串

使用“+”可以對(duì)多個(gè)字符串進(jìn)行拼接

語(yǔ)法格式: str1 + str2

>>> str1 = "aaa"
>>> str2 = "bbb"
>>> print(str1 + str2)
aaabbb

需要注意的是字符串不允許直接與其他類(lèi)型進(jìn)行拼接,例如

>>> num = 100
>>> str1 = "hello"
>>> print(str1 + num)
Traceback (most recent call last):
 File "<pyshell#5>", line 1, in <module>
 print(str1 + num)
TypeError: can only concatenate str (not "int") to str

上面這種情況我們可以將num轉(zhuǎn)換為字符串再進(jìn)行拼接

>>> num = 100
>>> str1 = "hello"
>>> print(str1 + str(num))
hello100

這樣就不會(huì)報(bào)錯(cuò)了

計(jì)算字符串的長(zhǎng)度

在Python中使用len()函數(shù)來(lái)計(jì)算字符串的長(zhǎng)度

語(yǔ)法格式: len(string)

>>> str1 = "hello"
>>> len(str1)
5
>>> str2 = "你好"
>>> len(str2)
2
>>> str3 = "1111"
>>> len(str3)
4

從上面的結(jié)果我們可以看出,在默認(rèn)情況下,len函數(shù)在計(jì)算字符串的長(zhǎng)度時(shí),無(wú)論是數(shù)字,字母還是多字節(jié)的漢字都認(rèn)為是一個(gè)字符。

為什么說(shuō)是默認(rèn)情況下呢,因?yàn)樵趯?shí)際開(kāi)發(fā)中,可能因?yàn)槲覀儾扇〉木幋a不同,字符串實(shí)際所占的字節(jié)數(shù)也不同。

  • UTF-8編碼,漢字占3個(gè)字節(jié)
  • GBK或者GB2312,漢字占2個(gè)字節(jié)

這時(shí)我們可以通過(guò)使用encode()方法進(jìn)行編碼后再進(jìn)行獲取長(zhǎng)度。

例如:

>>> str1 = "你好"
>>> len(str1)
2
>>> len(str1.encode('gbk'))
4
>>> len(str1.encode('utf-8'))
6

截取字符串

語(yǔ)法格式: string[start : end : step]

參數(shù)說(shuō)明

  • string:表示要截取的字符串
  • start:表示要截取的第一個(gè)字符的索引(包括該字符),如果不指定,則默認(rèn)為0
  • end:表示要截取的最后一個(gè)字符的索引(不包括該字符),如果不指定則默認(rèn)為字符串的長(zhǎng)度。
  • step:表示切片的步長(zhǎng),如果省略,則默認(rèn)為1,當(dāng)省略該步長(zhǎng)時(shí),最后一個(gè)冒號(hào)也可以省略。
>>> str1 = "hello world!"
>>> str1[1]  #截取第2個(gè)字符
'e'
>>> str1[2:] #從第3個(gè)字符開(kāi)始截取
'llo world!'
>>> str1[:4]
'hell'
>>> str1[1:5]
'ello'
>>> str1[-1] #截取最后一個(gè)字符
'!'
>>> str1[2:-2]
'llo worl'

注意:字符串的索引是從0開(kāi)始的

分割字符串

python中分割字符串是使用split()方法把字符串分割成列表

語(yǔ)法格式 : str.split(sep, maxsplit)

參數(shù)說(shuō)明:

  • str:表示要進(jìn)行分割的字符串
  • sep:用于指定分隔符,可以包含多個(gè)字符,默認(rèn)為None,即所有空字符(包括空格、換行"n”、制表符“t”等)。
  • maxsplit:可選參數(shù),用于指定分割的次數(shù),如果不指定或者為-1,則分割次數(shù)沒(méi)有限制,否則返回結(jié)果列表的元素個(gè)數(shù)最多為 maxsplit+1
  • 返回值:分隔后的字符串列表。
>>> str1 = "i am a good boy!"
>>> str1.split() #采用默認(rèn)分割符進(jìn)行分割
['i', 'am', 'a', 'good', 'boy!']
>>> str1.split(" ") #采用空格進(jìn)行分割
['i', 'am', 'a', 'good', 'boy!']
>>> str1.split(" ", 3) #采用空格進(jìn)行分割,并且只分割前3個(gè)
['i', 'am', 'a', 'good boy!']

注意默認(rèn)情況下按空格分割

檢索字符串

python中字符串的查找方法

1、count()方法

語(yǔ)法格式 : str.count(sub[, start[, end]])

作用:用于檢索指定字符串在另一個(gè)字符串中出現(xiàn)的次數(shù),如果檢索的字符串不存在則返回0,否則返回出現(xiàn)的次數(shù)。

參數(shù)說(shuō)明

  • str:表示原字符串
  • sub:表示要檢索的子字符串
  • start:可選參數(shù),表示檢索范圍的起始位置的索引,如果不指定,則從頭開(kāi)始檢索
  • end:可選參數(shù),表示檢索范圍的結(jié)束位置的索引,如果不指定,則一直檢索到結(jié)尾
>>> str1 = "hello world"
>>> print(str1.count('o'))
2

2、find()方法

語(yǔ)法格式 : str.find(sub[, start[, end]])

作用:檢索是否包含指定的字符串,如果檢索的字符串不存在則返回-1,否則返回首次出現(xiàn)該字符串時(shí)的索引。

>>> str1 = "hello world!"
>>> str1.find('wo')
6

3、index()方法

語(yǔ)法格式 : str.index(sub[, start[, end]])

作用:和find方法類(lèi)似,也用于檢索是否包含指定的字符串,使用index方法,當(dāng)指定的字符串不存在時(shí)會(huì)拋異常。

>>> str1 = "hello world!"
>>> str1.index('w')
6
>>> str1.index('m')
Traceback (most recent call last):
 File "<pyshell#6>", line 1, in <module>
 str1.index('m')
ValueError: substring not found
>>> str1.find('m')
-1

4、startswith()方法

語(yǔ)法格式 : str.startswith(prefix[, start[, end]])

作用:檢索字符串是否以指定的字符串開(kāi)頭,如果是則返回true,否則返回false。

>>> str1 = "hello world!"
>>> str1.startswith('hello')
True
>>> str1.startswith('hi')
False
>>>

5、endswith()方法

語(yǔ)法格式 : str.endswith(prefix[, start[, end]])

作用:檢索字符串是否以指定的字符串結(jié)尾,如果是則返回true,否則返回false。

>>> str1 = "hello world!"
>>> str1.endswith('world!')
True
>>> str1.endswith('haha')
False

字符串的大小寫(xiě)轉(zhuǎn)換

1、lower()方法

語(yǔ)法格式 : str.lower()

作用:將字符串中的大寫(xiě)字母轉(zhuǎn)換為小寫(xiě)字母

>>> str1 = "Hello World!"
>>> str1.lower()
'hello world!'

2、upper()方法

語(yǔ)法格式 : str.upper()

作用:將字符串中的小寫(xiě)字母轉(zhuǎn)換為大寫(xiě)字母

>>> str1 = "Hello World!"
>>> str1.upper()
'HELLO WORLD!'

去除字符串中的空格和特殊字符

開(kāi)發(fā)中,我們會(huì)遇到這樣的需求,字符串前后(左右側(cè))不允許出現(xiàn)空格和特殊字符或者將用戶輸入的字符串中誤輸入的空格去除掉。這時(shí)我們就需要用到strip函數(shù)。

1、strip()方法

語(yǔ)法格式 : str.strip([chars])

作用:去除字符串前后(左右側(cè))的空格或特殊字符

>>> str1 = " hello world! "
>>> str1.strip()
'hello world!'
>>> str2 = "#hello world#@#"
>>> str2.strip('#')
'hello world#@'
>>> str3 = "@hello world!@."
>>> str3.strip('@.')
'hello world!'

2、lstrip()方法

語(yǔ)法格式 : str.lstrip([chars])

作用:去除字符串前面(左側(cè))的空格或特殊字符

>>> str1 = " hello world! "
>>> str1.lstrip()
'hello world! '
>>> str2 = "#hello world#@#"
>>> str2.lstrip('#')
'hello world#@#'
>>> str3 = "@.hello world!@."
>>> str3.lstrip('@.')
'hello world!@.'

3、rstrip()方法

語(yǔ)法格式 : str.rstrip([chars])

作用:去除字符串后面(右側(cè))的空格或特殊字符

>>> str1 = " hello world! "
>>> str1.rstrip()
' hello world!'
>>> str2 = "#hello world#@#"
>>> str2.rstrip('#')
'#hello world#@'
>>> str3 = "@.hello world!@."
>>> str3.rstrip('@.')
'@.hello world!'

格式化字符串

所謂格式化字符串就是先制定一個(gè)模板,在模板中預(yù)留幾個(gè)空位,然后根據(jù)需要填上相應(yīng)的內(nèi)容。

使用“%”操作符

語(yǔ)法格式: '%[-][+][0][.n]格式化字符'%exp

參數(shù)說(shuō)明

  • -:可選參數(shù),用于指定左對(duì)齊,正數(shù)前方無(wú)符號(hào),負(fù)數(shù)前面加負(fù)號(hào)
  • +:可選參數(shù),用于指定右對(duì)齊,正數(shù)前方加正號(hào),負(fù)數(shù)前方加負(fù)號(hào)
  • 0:可選參數(shù),表示右對(duì)齊,正數(shù)前方無(wú)符號(hào),負(fù)數(shù)前方加負(fù)號(hào),用0填充空白處(一般與m參數(shù)一起使用)
  • m:可選參數(shù),表示占有寬度
  • n:可選參數(shù),表示小數(shù)點(diǎn)后保留的位數(shù)
  • 格式化字符:用于指定類(lèi)型,其值如下表所示

exp:要轉(zhuǎn)換的項(xiàng),如果要指定的項(xiàng)有多個(gè),需要通過(guò)元組的形式進(jìn)行指定,但不能使用列表。

>>> template = '學(xué)號(hào):%d,姓名:%s,班級(jí):%s'
>>> print(template% (123,'張三','一年級(jí)'))
學(xué)號(hào):123,姓名:張三,班級(jí):一年級(jí)

總結(jié)

以上所述是小編給大家介紹的Python中常用的8種字符串操作方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • Python實(shí)現(xiàn)解析Html的方法與對(duì)比

    Python實(shí)現(xiàn)解析Html的方法與對(duì)比

    在最近需要的需求中,需要?python?獲取網(wǎng)頁(yè)內(nèi)容,并從html中獲取到想要的內(nèi)容,本文主要介紹了兩種常用方法并進(jìn)行了對(duì)比,感興趣的可以了解下
    2024-03-03
  • python矩陣列的實(shí)現(xiàn)示例

    python矩陣列的實(shí)現(xiàn)示例

    在Python和NumPy庫(kù)的幫助下,矩陣列可以很容易地進(jìn)行各種操作,本文主要介紹了python矩陣列的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • Python 中如何使用 setLevel() 設(shè)置日志級(jí)別

    Python 中如何使用 setLevel() 設(shè)置日志級(jí)別

    這篇文章主要介紹了在 Python 中使用setLevel() 設(shè)置日志級(jí)別,Python 提供了一個(gè)單獨(dú)的日志記錄模塊作為其標(biāo)準(zhǔn)庫(kù)的一部分,以簡(jiǎn)化日志記錄,本文將討論日志記錄 setLevel 及其在 Python 中的工作方式,需要的朋友可以參考下
    2023-07-07
  • Python制作腳本幫女朋友搶購(gòu)清空購(gòu)物車(chē)

    Python制作腳本幫女朋友搶購(gòu)清空購(gòu)物車(chē)

    這篇文章主要介紹了Python制作的搶購(gòu)清空購(gòu)物車(chē)的腳本,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • python 截取 取出一部分的字符串方法

    python 截取 取出一部分的字符串方法

    下面小編就為大家?guī)?lái)一篇python 截取 取出一部分的字符串方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • 如何用Django處理gzip數(shù)據(jù)流

    如何用Django處理gzip數(shù)據(jù)流

    這篇文章主要介紹了如何用Django處理gzip數(shù)據(jù)流,幫助大家更好的理解和使用django框架,感興趣的朋友可以了解下
    2021-01-01
  • tracemalloc分析內(nèi)存使用情況與泄露方式

    tracemalloc分析內(nèi)存使用情況與泄露方式

    這篇文章主要介紹了tracemalloc分析內(nèi)存使用情況與泄露方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • python如何給字典的鍵對(duì)應(yīng)的值為字典項(xiàng)的字典賦值

    python如何給字典的鍵對(duì)應(yīng)的值為字典項(xiàng)的字典賦值

    這篇文章主要介紹了python如何給字典的鍵對(duì)應(yīng)的值為字典項(xiàng)的字典賦值,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Python?3行代碼提取音樂(lè)高潮部分

    Python?3行代碼提取音樂(lè)高潮部分

    這篇文章主要介紹了利用Python代碼提取音樂(lè)高潮部分,文章圍繞Python代碼的相關(guān)詳情展開(kāi)提取音樂(lè)的內(nèi)容,需要的小伙伴可以參考一下
    2022-01-01
  • python實(shí)現(xiàn)在列表中查找某個(gè)元素的下標(biāo)示例

    python實(shí)現(xiàn)在列表中查找某個(gè)元素的下標(biāo)示例

    這篇文章主要介紹了python實(shí)現(xiàn)在列表中查找某個(gè)元素的下標(biāo)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11

最新評(píng)論