Python3字符串
Python訪問字符串中的值
Python中的字符串用單引號(')或雙引號(")括起來,同時(shí)使用反斜杠()轉(zhuǎn)義特殊字符丐吓。
獲取字符串中的單個(gè)字符的語法格式如下:
<font color=#00aa00>字符串變量[下標(biāo)]</font>
注意:下標(biāo)的返回是0~字符串長度-1
# 獲取第一個(gè)字符
print(var[0])
# 獲取第3個(gè)字符
print(var[2])
# 獲取最后一個(gè)字符
print(var[-1])
# 獲取倒數(shù)第二個(gè)字符
print(var[-2])
--
字符串的截取的語法格式如下:
<font color=#00aa00> 字符串變量[頭下標(biāo):尾下標(biāo)] </font>
# 獲取從第2個(gè)開始到第3個(gè)的所有字符
print(var[1:3])
# 獲取從第一個(gè)開始到第4個(gè)的所有字符
print(var[:4])
# 獲取從第三個(gè)字符開始后面所有的字符
print(var[2:])
# 獲取從第4個(gè)字符開始到倒數(shù)第二個(gè)的所有字符
print(var[4:-1])
--
Python字符串運(yùn)算符
下表實(shí)例變量a值為字符串 "Hello",b變量值為 "Python":
|操作符 |描述| 實(shí)例
|---|---|---|
- |字符串連接| a + b 輸出結(jié)果: HelloPython
|重復(fù)輸出字符串|a2 輸出結(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)義特殊或不能打印的字符缩举。 原始字符串除在字符串的第一個(gè)引號前加上字母 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á)式例获,但最基本的用法是將一個(gè)值插入到一個(gè)有字符串格式符 %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() | 將字符串的第一個(gè)字符轉(zhuǎn)換為大寫 |
2 | center(width, fillchar) | 返回一個(gè)指定的寬度 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 對象,這個(gè) bytes 對象可以由 str.encode() 來編碼返回祥山。 |
5 | encode(encoding='UTF-8',errors='strict') | 以 encoding 指定的編碼格式編碼字符串圃验,如果出錯(cuò)默認(rèn)報(bào)一個(gè)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不在字符串中會報(bào)一個(gè)異常. |
10 | isalnum() | 如果字符串至少有一個(gè)字符并且所有字符都是字母或數(shù)字則返 回 True,否則返回 False |
11 | isalpha() | 如果字符串至少有一個(gè)字符并且所有字符都是字母則返回 True, 否則返回 False |
12 | isdigit() | 如果字符串只包含數(shù)字則返回 True 否則返回 False.. |
13 | islower() | 如果字符串中包含至少一個(gè)區(qū)分大小寫的字符悲立,并且所有這些(區(qū)分大小寫的)字符都是小寫,則返回 True新博,否則返回 False |
14 | isnumeric() | 如果字符串中只包含數(shù)字字符薪夕,則返回 True,否則返回 False(中文數(shù)字也可以) |
15 | isspace() | 如果字符串中只包含空白赫悄,則返回 True原献,否則返回 False. |
16 | istitle() | 如果字符串是標(biāo)題化的(見 title())則返回 True馏慨,否則返回 False |
17 | isupper() | 如果字符串中包含至少一個(gè)區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是大寫姑隅,則返回 True写隶,否則返回 False |
18 | join(seq) | 以指定字符串作為分隔符,將 seq 中所有的元素(的字符串表示)合并為一個(gè)新的字符串 |
19 | len(string) | 返回字符串長度 |
20 | ljust(width[, fillchar]) | 返回一個(gè)原字符串左對齊,并使用 fillchar 填充至長度 width 的新字符串讲仰,fillchar 默認(rèn)為空格慕趴。 |
21 | lower() | 轉(zhuǎn)換字符串中所有大寫字符為小寫. |
22 | lstrip() | 截掉字符串左邊的空格或指定字符。 |
23 | maketrans() | 創(chuàng)建字符映射的轉(zhuǎn)換表鄙陡,對于接受兩個(gè)參數(shù)的最簡單的調(diào)用方式冕房,第一個(gè)參數(shù)是字符串,表示需要轉(zhuǎn)換的字符趁矾,第二個(gè)參數(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]) | 返回一個(gè)原字符串右對齊,并使用fillchar(默認(rèn)空格)填充至長度 width 的新字符串 |
30 | rstrip() | 刪除字符串字符串末尾的空格. |
31 | split(str="", num=string.count(str)) | num=string.count(str)) 以 str 為分隔符截取字符串,如果 num 有指定值牌柄,則僅截取 num 個(gè)子字符串 |
32 | splitlines([keepends]) | 按照行('\r', '\r\n', \n')分隔,返回一個(gè)包含各行作為元素的列表侧甫,如果參數(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 個(gè)字符)轉(zhuǎn)換 string 的字符, 要過濾掉的字符放到 deletechars 參數(shù)中 |
38 | upper() | 轉(zhuǎn)換字符串中的小寫字母為大寫 |
39 | zfill (width) | 返回長度為 width 的字符串俺叭,原字符串右對齊恭取,前面填充0 |
40 | isdecimal() | 檢查字符串是否只包含十進(jìn)制字符,如果是返回 true熄守,否則返回 false蜈垮。 |