Python3字符串
Python訪問字符串中的值
Python中的字符串用單引號(')或雙引號(")括起來,同時使用反斜杠()轉(zhuǎn)義特殊字符冲粤。
獲取字符串中的單個字符的語法格式如下:
<font color=#00aa00>字符串變量[下標(biāo)]</font>
注意:下標(biāo)的返回是0~字符串長度-1
# 獲取第一個字符
print(var[0])
# 獲取第3個字符
print(var[2])
# 獲取最后一個字符
print(var[-1])
# 獲取倒數(shù)第二個字符
print(var[-2])
--
字符串的截取的語法格式如下:
<font color=#00aa00> 字符串變量[頭下標(biāo):尾下標(biāo)] </font>
# 獲取從第2個開始到第3個的所有字符
print(var[1:3])
# 獲取從第一個開始到第4個的所有字符
print(var[:4])
# 獲取從第三個字符開始后面所有的字符
print(var[2:])
# 獲取從第4個字符開始到倒數(shù)第二個的所有字符
print(var[4:-1])
--
Python字符串運(yùn)算符
下表實(shí)例變量a值為字符串 "Hello"适刀,b變量值為 "Python":
操作符 | 描述 | 實(shí)例 |
---|---|---|
+ | 字符串連接 | a + b 輸出結(jié)果: HelloPython |
* | 重復(fù)輸出字符串 | a*2 輸出結(jié)果:HelloHello |
[] | 通過索引獲取字符串中字符 | a[1] 輸出結(jié)果 e |
[ : ] | 截取字符串中的一部分 | a[1:4] 輸出結(jié)果 ell |
in | 成員運(yùn)算符 - 如果字符串中包含給定的字符返回 True | 'H' in a 輸出結(jié)果 1 |
not in | 成員運(yùn)算符 - 如果字符串中不包含給定的字符返回 True | 'M' not in a 輸出結(jié)果 1 |
r/R | 原始字符串 - 原始字符串:所有的字符串都是直接按照字面的意思來使用,沒有轉(zhuǎn)義特殊或不能打印的字符娜饵。 原始字符串除在字符串的第一個引號前加上字母 r(可以大小寫)以外,與普通字符串有著幾乎完全相同的語法。 | print( r'\n' )print( R'\n' ) |
% | 格式字符串 |
a = 'Hello'
b = 'Python'
print(a + ' ' + b) # 打痈馍骸:Hello Python
str1 = a * 3
print(str1) # 打印:HelloHelloHello
re = 'He' in a
print(re) # 打雍宥:True
re = 'He' not in a
print(re) # 打印: False
?
Python字符串格式化
Python 支持格式化字符串的輸出 。盡管這樣可能會用到非常復(fù)雜的表達(dá)式侍咱,但最基本的用法是將一個值插入到一個有字符串格式符 %s 的字符串中耐床。
在 Python 中,字符串格式化使用與 C 中 sprintf 函數(shù)一樣的語法楔脯。
print ("我叫 %s 今年 %d 歲!" % ('小明', 10))
python字符串格式化符號:
符號 | 描述 |
---|---|
%c | 格式化字符及其ASCII碼 |
%s | 格式化字符串 |
%d | 格式化整數(shù) |
%u | 格式化無符號整型 |
%o | 格式化無符號八進(jìn)制數(shù) |
%x | 格式化無符號十六進(jìn)制數(shù) |
%X | 格式化無符號十六進(jìn)制數(shù)(大寫) |
%f | 格式化浮點(diǎn)數(shù)字撩轰,可指定小數(shù)點(diǎn)后的精度 |
%e | 用科學(xué)計(jì)數(shù)法格式化浮點(diǎn)數(shù) |
%E | 作用同%e,用科學(xué)計(jì)數(shù)法格式化浮點(diǎn)數(shù) |
%g | %f和%e的簡寫 |
%G | %f 和 %E 的簡寫 |
--
Python 的字符串內(nèi)建函數(shù)
Python 的字符串常用內(nèi)建函數(shù)如下:
序號 | 方法 | 描述 |
---|---|---|
1 | capitalize() | 將字符串的第一個字符轉(zhuǎn)換為大寫 |
2 | center(width, fillchar) | 返回一個指定的寬度 width 居中的字符串昧廷,fillchar 為填充的字符堪嫂,默認(rèn)為空格。 |
3 | count(str) | 返回 str 在 string 里面出現(xiàn)的次數(shù) |
4 | bytes.decode(encoding="utf-8", errors="strict") | Python3 中沒有 decode 方法木柬,但我們可以使用 bytes 對象的 decode() 方法來解碼給定的 bytes 對象皆串,這個 bytes 對象可以由 str.encode() 來編碼返回。 |
5 | encode(encoding='UTF-8',errors='strict') | 以 encoding 指定的編碼格式編碼字符串弄诲,如果出錯默認(rèn)報一個ValueError 的異常愚战,除非 errors 指定的是'ignore'或者'replace' |
6 | endswith(suffix) | 檢查字符串是否以 obj 結(jié)束,如果beg 或者 end 指定則檢查指定的范圍內(nèi)是否以 obj 結(jié)束齐遵,如果是寂玲,返回 True,否則返回 False. |
7 | expandtabs(tabsize=8) | 把字符串 string 中的 tab 符號轉(zhuǎn)為空格,tab 符號默認(rèn)的空格數(shù)是 8 梗摇。 |
8 | find(str, beg=0 end=len(string)) | 檢測 str 是否包含在字符串中拓哟,如果指定范圍 beg 和 end ,則檢查是否包含在指定范圍內(nèi)伶授,如果包含返回開始的索引值断序,否則返回-1 |
9 | index(str, beg=0, end=len(string)) | 跟find()方法一樣流纹,只不過如果str不在字符串中會報一個異常. |
10 | isalnum() | 如果字符串至少有一個字符并且所有字符都是字母或數(shù)字則返 回 True,否則返回 False |
11 | isalpha() | 如果字符串至少有一個字符并且所有字符都是字母則返回 True, 否則返回 False |
12 | isdigit() | 如果字符串只包含數(shù)字則返回 True 否則返回 False.. |
13 | islower() | 如果字符串中包含至少一個區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是小寫违诗,則返回 True漱凝,否則返回 False |
14 | isnumeric() | 如果字符串中只包含數(shù)字字符,則返回 True诸迟,否則返回 False(中文數(shù)字也可以) |
15 | isspace() | 如果字符串中只包含空白茸炒,則返回 True,否則返回 False. |
16 | istitle() | 如果字符串是標(biāo)題化的(見 title())則返回 True阵苇,否則返回 False |
17 | isupper() | 如果字符串中包含至少一個區(qū)分大小寫的字符壁公,并且所有這些(區(qū)分大小寫的)字符都是大寫,則返回 True绅项,否則返回 False |
18 | join(seq) | 以指定字符串作為分隔符紊册,將 seq 中所有的元素(的字符串表示)合并為一個新的字符串 |
19 | len(string) | 返回字符串長度 |
20 | ljust(width[, fillchar]) | 返回一個原字符串左對齊,并使用 fillchar 填充至長度 width 的新字符串,fillchar 默認(rèn)為空格快耿。 |
21 | lower() | 轉(zhuǎn)換字符串中所有大寫字符為小寫. |
22 | lstrip() | 截掉字符串左邊的空格或指定字符囊陡。 |
23 | maketrans() | 創(chuàng)建字符映射的轉(zhuǎn)換表,對于接受兩個參數(shù)的最簡單的調(diào)用方式掀亥,第一個參數(shù)是字符串关斜,表示需要轉(zhuǎn)換的字符,第二個參數(shù)也是字符串表示轉(zhuǎn)換的目標(biāo)铺浇。 |
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()函數(shù)吼拥,不過是從右邊開始查找. |
28 | rindex( str, beg=0, end=len(string)) | 類似于 index()倚聚,不過是從右邊開始. |
29 | rjust(width,[, fillchar]) | 返回一個原字符串右對齊,并使用fillchar(默認(rèn)空格)填充至長度 width 的新字符串 |
30 | rstrip() | 刪除字符串字符串末尾的空格. |
31 | split(str="", num=string.count(str)) | num=string.count(str)) 以 str 為分隔符截取字符串,如果 num 有指定值凿可,則僅截取 num 個子字符串 |
32 | splitlines([keepends]) | 按照行('\r', '\r\n', \n')分隔惑折,返回一個包含各行作為元素的列表,如果參數(shù) keepends 為 False枯跑,不包含換行符惨驶,如果為 True,則保留換行符敛助。 |
33 | startswith(str, beg=0,end=len(string)) | 檢查字符串是否是以 obj 開頭粗卜,是則返回 True,否則返回 False纳击。如果beg 和 end 指定值续扔,則在指定范圍內(nèi)檢查攻臀。 |
34 | strip([chars]) | 在字符串上執(zhí)行 lstrip()和 rstrip() |
35 | swapcase() | 將字符串中大寫轉(zhuǎn)換為小寫,小寫轉(zhuǎn)換為大寫 |
36 | title() | 返回"標(biāo)題化"的字符串,就是說所有單詞都是以大寫開始纱昧,其余字母均為小寫(見 istitle()) |
37 | translate(table, deletechars="") | 根據(jù) str 給出的表(包含 256 個字符)轉(zhuǎn)換 string 的字符, 要過濾掉的字符放到 deletechars 參數(shù)中 |
38 | upper() | 轉(zhuǎn)換字符串中的小寫字母為大寫 |
39 | zfill (width) | 返回長度為 width 的字符串刨啸,原字符串右對齊,前面填充0 |
40 | isdecimal() | 檢查字符串是否只包含十進(jìn)制字符识脆,如果是返回 true设联,否則返回 false。 |