1. 程式人生 > 實用技巧 >二、Python基本資料型別二:字串型別

二、Python基本資料型別二:字串型別

1、字串數值表示

·可以用成對的單引號或者雙引號表示

·用三個連續的單引號可表示多行字串

>>> 'abc', "abc"
('abc', 'abc')
>>> '''你好
世界!'''
'你好\n 世界!'
>>> '''Hello

World!'''
'Hello\n\n World!'

·特殊符號用轉移符號“\”表示

2、字串通過下標引用元素

·字串中第一個字元的編號為0,第二個為1,……

·字串中最後一個字元的編號為-1,倒數第二個為-2,……

>>> s = "My name is Lily"
>>> s[-3]
'i'
>>> s[3]
'n'

3、常見字串操作

(1)切片

·s[start : end : step]startend表示切片範圍[start, end)step表示步長)

>>> s = 'Hello World!'
>>> s[1 : 7 : 2]
'el '
>>> s[1 : 8 :2]
'el o'

·split(sp,maxsplit),按指定字元sp(預設空格)將原字串切割為多個字串,用maxsplit指定最大切割次數,最終返回切割後的字串所組成的列表

>>> s = 'Hello World!'
>>> sp = s.split('l')
>>> sp
['He', '', 'o Wor', 'd!']

(2)大小寫轉換

·upper()# 全部大寫

·lower()# 全部小寫

·swapcase()# 大小寫互換

·capitalize()

# 首字母大寫,其餘小寫

·title()# 標題格式,單詞首字母大寫

>>> s = 'Hello World!'
>>> print(s.upper(), "\n",  s.lower(), "\n", s.title())
HELLO WORLD! 
 hello world! 
 Hello World!
>>> print(s.swapcase(), "\n", s.capitalize())
hELLO wORLD! 
 Hello world!

(3)替換

·replace(old,new,count)

new替換字串中的oldcount指定替換的最大次數,預設(不指定)替換全部,產生新的字串

>>> s = 'Hello World!'
>>> print(s.replace('l', 'p'), '\n', s.replace('l', 'p', 2))
Heppo Worpd! 
 Heppo World!

(4)去空格和指定字元

·strip(),刪除字串兩端的空白字元,可以指定刪除的字元

·lstrip(),刪除字串左邊的空白字元,可以指定刪除的字元

·rstrip(),刪除字串末尾的空白字元,可以指定刪除的字元

>>> s = 'aab ccc baa'
>>> print(s.strip('a'), '\n', s.lstrip('a'), '\n', s.rstrip('a'))
b ccc b 
 b ccc baa 
 aab ccc b

(5)格式化對齊相關

·ljust(width, fillstr)左對齊,右邊用fillstr指定的字元(預設用空格)補齊

·rjust(width, fillstr) 右對齊,左邊用fillstr指定的字元(預設用空格)補齊

·center(width, fillstr)   居中,兩邊用fillstr指定的字元(預設用空格)補齊

·zfill(10)        右對齊,左邊用0補齊

>>> s = 'a bc'
>>> print(s.ljust(10,'*'), '\n', s.rjust(10,'-'), '\n', s.center(10), '\n', s.zfill(10))
a bc****** 
 ------a bc 
    a bc    
 000000a bc

(6)字串查詢函式

·find(str, start, end)搜尋指定字串,沒有返回-1

·index(str, start, end)同上,但是找不到會報錯,搜尋區間為左閉右開

·rfind(str, start, end)從右邊開始查詢

·count(str, start, end)統計指定的字串出現的次數

(7)字串查詢函式

·startswith('start') 是否以start開頭

·endswith('end') 是否以end結尾

·isalnum() 是否全為字母或數字

·isalpha() 是否全字母

·isdigit() 是否全數字

·islower() 是否全小寫

·isupper() 是否全大寫

·istitle() 判斷首字母是否為大寫

·isspace() 判斷字元是否為空格

4、常用函式補充

1

capitalize()
將字串的第一個字元轉換為大寫

2

center(width, fillchar)
返回一個指定的寬度 width 居中的字串,fillchar 為填充的字元,預設為空格。

3

count(str, beg= 0,end=len(string))
返回 str 在 string 裡面出現的次數,如果 beg 或者 end 指定則返回指定範圍內 str 出現的次數

4

bytes.decode(encoding="utf-8", errors="strict")
Python3 中沒有 decode 方法,但我們可以使用 bytes 物件的 decode() 方法來解碼給定的 bytes 物件,這個 bytes 物件可以由 str.encode() 來編碼返回。

5

encode(encoding='UTF-8',errors='strict')
以 encoding 指定的編碼格式編碼字串,如果出錯預設報一個ValueError 的異常,除非 errors 指定的是'ignore'或者'replace'

6

endswith(suffix, beg=0, end=len(string))
檢查字串是否以 obj 結束,如果beg 或者 end 指定則檢查指定的範圍內是否以 obj 結束,如果是,返回 True,否則返回 False.

7

expandtabs(tabsize=8)
把字串 string 中的 tab 符號轉為空格,tab 符號預設的空格數是 8 。

8

find(str, beg=0, end=len(string))
檢測 str 是否包含在字串中,如果指定範圍 beg 和 end ,則檢查是否包含在指定範圍內,如果包含返回開始的索引值,否則返回-1

9

index(str, beg=0, end=len(string))
跟find()方法一樣,只不過如果str不在字串中會報一個異常。

10

isalnum()
如果字串至少有一個字元並且所有字元都是字母或數字則返回True,否則返回 False

11

isalpha()
如果字串至少有一個字元並且所有字元都是字母或中文字則返回 True, 否則返回 False

12

isdigit()
如果字串只包含數字則返回 True 否則返回 False..

13

islower()
如果字串中包含至少一個區分大小寫的字元,並且所有這些(區分大小寫的)字元都是小寫,則返回 True,否則返回 False

14

isnumeric()
如果字串中只包含數字字元,則返回 True,否則返回 False

15

isspace()
如果字串中只包含空白,則返回 True,否則返回 False.

16

istitle()
如果字串是標題化的(見 title())則返回 True,否則返回 False

17

isupper()
如果字串中包含至少一個區分大小寫的字元,並且所有這些(區分大小寫的)字元都是大寫,則返回 True,否則返回 False

18

join(seq)
以指定字串作為分隔符,將 seq 中所有的元素(的字串表示)合併為一個新的字串

19

len(string)
返回字串長度

20

ljust(width[, fillchar])
返回一個原字串左對齊,並使用 fillchar 填充至長度 width 的新字串,fillchar 預設為空格。

21

lower()
轉換字串中所有大寫字元為小寫.

22

lstrip()
截掉字串左邊的空格或指定字元。

23

maketrans()
建立字元對映的轉換表,對於接受兩個引數的最簡單的呼叫方式,第一個引數是字串,表示需要轉換的字元,第二個引數也是字串表示轉換的目標。

24

max(str)
返回字串 str 中最大的字母。

25

min(str)
返回字串 str 中最小的字母。

26

replace(old, new [, max])
把 將字串中的 str1 替換成 str2,如果 max 指定,則替換不超過 max 次。

27

rfind(str, beg=0,end=len(string))

類似於 find()函式,不過是從右邊開始查詢.

28

rindex( str, beg=0, end=len(string))
類似於 index(),不過是從右邊開始.

29

rjust(width,[, fillchar])
返回一個原字串右對齊,並使用fillchar(預設空格)填充至長度 width 的新字串

30

rstrip()
刪除字串字串末尾的空格.

31

split(str="", num=string.count(str))
num=string.count(str)) 以 str 為分隔符擷取字串,如果 num 有指定值,則僅擷取 num+1 個子字串

32

splitlines([keepends])
按照行('\r', '\r\n', \n')分隔,返回一個包含各行作為元素的列表,如果引數 keepends 為 False,不包含換行符,如果為 True,則保留換行符。

33

startswith(substr, beg=0,end=len(string))
檢查字串是否是以指定子字串 substr 開頭,是則返回 True,否則返回 False。如果beg 和 end 指定值,則在指定範圍內檢查。

34

strip([chars])
在字串上執行 lstrip()和 rstrip()

35

swapcase()
將字串中大寫轉換為小寫,小寫轉換為大寫

36

title()
返回"標題化"的字串,就是說所有單詞都是以大寫開始,其餘字母均為小寫(見 istitle())

37

translate(table, deletechars="")
根據 str 給出的表(包含 256 個字元)轉換 string 的字元, 要過濾掉的字元放到 deletechars 引數中

38

upper()

轉換字串中的小寫字母為大寫

39

zfill (width)
返回長度為 width 的字串,原字串右對齊,前面填充0

40

isdecimal()
檢查字串是否只包含十進位制字元,如果是返回 true,否則返回 false。