python字串操作

2021-08-17 22:49:42 字數 4407 閱讀 1027

構建字串

一般使用引號(『或」)來建立字串。

var1 = 'hello world!'

var2 = "runoob

訪問字串

通過下標和切片訪問

print

("var1[0]: ", var1[0])

print

("var2[1:5]: ", var2[1:5])

字串格式化

利用格式化符號和fomat()函式進行格式化

#!/usr/bin/python3

print ("我叫 %s 今年 %d 歲!" % ('小明', 10))

print ("我叫 {}今年 {} 歲!" .format('小明', 10))

符   號

描述%c

格式化字元及其ascii碼

%s格式化字串

%d格式化整數

%u格式化無符號整型

%o格式化無符號八進位制數

%x格式化無符號十六進製制數

%x格式化無符號十六進製制數(大寫)

%f格式化浮點數字,可指定小數點後的精度

%e用科學計數法格式化浮點數

%e作用同%e,用科學計數法格式化浮點數

%g%f和%e的簡寫

%g%f 和 %e 的簡寫

%p用十六進製制數格式化變數的位址

格式化操作輔助命令符號

功能*定義寬度或者小數點精度

-用做左對齊

+在正數前面顯示加號( + )

在正數前面顯示空格

#在八進位制數前面顯示零(『0』),在十六進製制前面顯示』0x』或者』0x』(取決於用的是』x』還是』x』)

0顯示的數字前面填充』0』而不是預設的空格

%『%%』輸出乙個單一的』%』

(var)

對映變數(字典引數)

m.n.

m 是顯示的最小總寬度,n 是小數點後的位數(如果可用的話)

在python2中,普通字串是以8位ascii碼進行儲存的,而unicode字串則儲存為16位unicode字串,這樣能夠表示更多的字符集。使用的語法是在字串前面加上字首 u。

==在python3中,所有的字串都是unicode字串。==

python 的字串常用內建函式如下:

序號方法及描述

1capitalize()

將字串的第乙個字元轉換為大寫

2center(width, fillchar)

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

3count(str, beg= 0,end=len(string))

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

4bytes.decode(encoding=」utf-8」, errors=」strict」)

python3 中沒有 decode 方法,但我們可以使用 bytes 物件的 decode() 方法來解碼給定的 bytes 物件,這個 bytes 物件可以由 str.encode() 來編碼返回。

5encode(encoding=』utf-8』,errors=』strict』)

以 encoding 指定的編碼格式編碼字串,如果出錯預設報乙個valueerror 的異常,除非 errors 指定的是』ignore』或者』replace』

6endswith(suffix, beg=0, end=len(string))

檢查字串是否以 obj 結束,如果beg 或者 end 指定則檢查指定的範圍內是否以 obj 結束,如果是,返回 true,否則返回 false.

7expandtabs(tabsize=8)

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

8find(str, beg=0 end=len(string))

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

9index(str, beg=0, end=len(string))

跟find()方法一樣,只不過如果str不在字串中會報乙個異常.

10isalnum()

如果字串至少有乙個字元並且所有字元都是字母或數字則返 回 true,否則返回 false

11isalpha()

如果字串至少有乙個字元並且所有字元都是字母則返回 true, 否則返回 false

12isdigit()

如果字串只包含數字則返回 true 否則返回 false..

13islower()

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

14isnumeric()

如果字串中只包含數字字元,則返回 true,否則返回 false

15isspace()

如果字串中只包含空白,則返回 true,否則返回 false.

16istitle()

如果字串是標題化的(見 title())則返回 true,否則返回 false

17isupper()

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

18join(seq)

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

19len(string)

返回字串長度

20ljust(width[, fillchar])

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

21lower()

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

22lstrip()

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

23maketrans()

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

24max(str)

返回字串 str 中最大的字母。

25min(str)

返回字串 str 中最小的字母。

26replace(old, new [, max])

把 將字串中的 str1 替換成 str2,如果 max 指定,則替換不超過 max 次。

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

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

28rindex( str, beg=0, end=len(string))

類似於 index(),不過是從右邊開始.

29rjust(width,[, fillchar])

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

30rstrip()

刪除字串字串末尾的空格.

31split(str=」「, num=string.count(str))

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

32splitlines([keepends])

按照行(『\r』, 『\r\n』, \n』)分隔,返回乙個包含各行作為元素的列表,如果引數 keepends 為 false,不包含換行符,如果為 true,則保留換行符。

33startswith(str, beg=0,end=len(string))

檢查字串是否是以 obj 開頭,是則返回 true,否則返回 false。如果beg 和 end 指定值,則在指定範圍內檢查。

34strip([chars])

在字串上執行 lstrip()和 rstrip()

35swapcase()

將字串中大寫轉換為小寫,小寫轉換為大寫

36title()

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

37translate(table, deletechars=」「)

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

38upper()

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

39zfill (width)

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

40isdecimal()

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

Python字串操作

1 複製字串 str2 str1 2 鏈結字串 str abc 3 查詢字串 string.find sub string.index sub string.rfind sub string,rindex sub 4 字串比較 cmp str1,str2 cmp str1.upper str2.up...

Python字串操作

python如何判斷乙個字串只包含數字字元 python 字串比較 下面列出了常用的python實現的字串操作 strcpy sstr1,sstr2 sstr1 strcpy sstr2 sstr1 sstr1 strcpy2 print sstr2 strcat sstr1,sstr2 sstr1...

python字串操作

在 python 有各種各樣的string操作函式。在歷史上string類在 python 中經歷了一段輪迴的歷史。在最開始的時候,python 有乙個專門的string的module,要使用string的方法要先import,但後來由於眾多的 python 使用者的建議,從 python 2.0開...