-
字符串
- python中,字符串可使用單引號'包括,也可使用雙引號"包括
- python不支持單字符類型(char),單字符也是字符串
- 字符串截取通過[]實現(xiàn),例如str[0],第一個字符,str[1:5]包括1不包括5中間的字符
轉(zhuǎn)義字符
符號 | 含義 |
---|---|
轉(zhuǎn)義字符 | 描述 |
\(在行尾時) | 續(xù)行符 |
\ \ | 反斜杠符號 |
\' | 單引號 |
\" | 雙引號 |
\a | 響鈴 |
\b | 退格(Backspace) |
\e | 轉(zhuǎn)義 |
\000 | 空 |
\n | 換行 |
\v | 縱向制表符 |
\t | 橫向制表符 |
\r | 回車 |
\f | 換頁 |
\oyy | 八進制數(shù),yy代表的字符,例如:\o12代表換行 |
\xyy | 十六進制數(shù),yy代表的字符,例如:\x0a代表換行 |
\other | 其它的字符以普通格式輸出 |
字符串運算符
操作符 | 描述 | 實例 |
---|---|---|
+ | 字符串連接 | a + b 輸出結果: HelloPython |
* | 重復輸出字符串 | a*2 輸出結果:HelloHello |
[] | 通過索引獲取字符串中字符 | a[1] 輸出結果 e |
[ : ] | 截取字符串中的一部分 | a[1:4] 輸出結果 ell |
in | 成員運算符(包含返回True) | 'H' in a 輸出結果 1 |
not in | 成員運算符(不包含返回 True) | 'M' not in a 輸出結果 1 |
r/R | 原始字符串,保持字符串字面值,不進行轉(zhuǎn)義等 | print( r'\n' ) print( R'\n' ) |
% | 格式化字符串 | %d,%s |
#coding=utf-8
str01 = 'Hello World!'
str02 = "JianShu"
print("str01[0]:",str01[0])
print("str02[1:5]:",str02[1:5])
print("str01[:7]+str02:",str01[:6]+str02)
print('str01+str02:',str01+str02)
print('str01*2:',str01*2)
print('"e" in str01:',"e" in str01)
print(r'\n')
print(R'\n')
image.png
格式化符號
符號 | 描述 |
---|---|
%c | 格式化字符及其ASCII碼 |
%s | 格式化字符串 |
%d | 格式化整數(shù) |
%u | 格式化無符號整型 |
%o | 格式化無符號八進制數(shù) |
%x | 格式化無符號十六進制數(shù) |
%X | 格式化無符號十六進制數(shù)(大寫) |
%f | 格式化浮點數(shù)字,可指定小數(shù)點后的精度 |
%e | 用科學計數(shù)法格式化浮點數(shù) |
%E | 作用同%e,用科學計數(shù)法格式化浮點數(shù) |
%g | %f和%e的簡寫 |
%G | %f 和 %E 的簡寫 |
%p | 用十六進制數(shù)格式化變量的地址 |
* | 定義寬度或者小數(shù)點精度 |
- | 用做左對齊 |
+ | 在正數(shù)前面顯示加號( + ) |
<sp> | 在正數(shù)前面顯示空格 |
# | 在八進制數(shù)前面顯示零('0'),在十六進制前面顯示'0x'或者'0X'(取決于用的是'x'還是'X') |
0 | 顯示的數(shù)字前面填充'0'而不是默認的空格 |
% | '%%'輸出一個單一的'%' |
(var) | 映射變量(字典參數(shù)) |
m.n. | m 是顯示的最小總寬度,n 是小數(shù)點后的位數(shù)(如果可用的話) |
三引號
- python三引號允許一個字符串跨多行,字符串中支持換行符,制表符以及其他特殊字符
- 字符串的格式是所謂的WYSIWYG(所見即所得)格式
- 當需要一段HTML或者SQL時,直接使用三引號,可避免繁瑣的轉(zhuǎn)義
#coding=utf-8
str = '''str01 = 'Hello World!'
str02 = "JianShu"
print("str01[0]:",str01[0])
print("str02[1:5]:",str02[1:5])
print("str01[:7]+str02:",str01[:6]+str02)
print('str01+str02:',str01+str02)
print('str01*2:',str01*2)
print('"e" in str01:',"e" in str01)
print(r'\n')
print(R'\n')
'''
print(str)
image.png
字符串常用方法
方法 | 含義 |
---|---|
capitalize() | 將字符串的第一個字符轉(zhuǎn)換為大寫 |
center(width, fillchar) | 返回一個指定的寬度 width 居中的字符串,fillchar 為填充的字符,默認為空格 |
count(str, beg= 0,end=len(string)) | 返回 str 在 string 里面出現(xiàn)的次數(shù),如果 beg 或者 end 指定則返回指定范圍內(nèi) str 出現(xiàn)的次數(shù) |
bytes.decode(encoding="utf-8", errors="strict") | Python3 中沒有 decode 方法,但我們可以使用 bytes 對象的 decode() 方法來解碼給定的 bytes 對象,這個 bytes 對象可以由 str.encode() 來編碼返回 |
encode(encoding='UTF-8',errors='strict') | 以 encoding 指定的編碼格式編碼字符串,如果出錯默認報一個ValueError 的異常,除非 errors 指定的是'ignore'或者'replace' |
endswith(suffix, beg=0, end=len(string)) | 檢查字符串是否以 obj 結束,如果beg 或者 end 指定則檢查指定的范圍內(nèi)是否以 obj 結束,如果是,返回 True,否則返回 False. |
expandtabs(tabsize=8) | 把字符串 string 中的 tab 符號轉(zhuǎn)為空格,tab 符號默認的空格數(shù)是 8 |
find(str, beg=0 end=len(string)) | 檢測 str 是否包含在字符串中,如果指定范圍 beg 和 end,則檢查是否包含在指定范圍內(nèi),如果包含返回開始的索引值,否則返回-1 |
index(str, beg=0, end=len(string)) | 跟find()方法一樣,只不過如果str不在字符串中會報一個異常. |
isalnum() | 如果字符串至少有一個字符并且所有字符都是字母或數(shù)字則返 回 True,否則返回 False |
isalpha() | 如果字符串至少有一個字符并且所有字符都是字母則返回 True, 否則返回 False |
isdigit() | 如果字符串只包含數(shù)字則返回 True 否則返回 False.. |
islower() | 如果字符串中包含至少一個區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是小寫,則返回 True,否則返回 False |
isnumeric() | 如果字符串中只包含數(shù)字字符,則返回 True,否則返回 False |
isspace() | 如果字符串中只包含空白,則返回 True,否則返回 False. |
istitle() | 如果字符串是標題化的(見 title())則返回 True,否則返回 False |
isupper() | 如果字符串中包含至少一個區(qū)分大小寫的字符,并且所有這些(區(qū)分大小寫的)字符都是大寫,則返回 True,否則返回 False |
join(seq) | 以指定字符串作為分隔符,將 seq 中所有的元素(的字符串表示)合并為一個新的字符串 |
len(string) | 返回字符串長度 |
ljust(width[, fillchar]) | 返回一個原字符串左對齊,并使用 fillchar 填充至長度 width 的新字符串,fillchar 默認為空格。 |
lower() | 轉(zhuǎn)換字符串中所有大寫字符為小寫. |
lstrip() | 截掉字符串左邊的空格或指定字符 |
maketrans() | 創(chuàng)建字符映射的轉(zhuǎn)換表,對于接受兩個參數(shù)的最簡單的調(diào)用方式,第一個參數(shù)是字符串,表示需要轉(zhuǎn)換的字符,第二個參數(shù)也是字符串表示轉(zhuǎn)換的目標 |
max(str) | 返回字符串 str 中最大的字母 |
min(str) | 返回字符串 str 中最小的字母 |
replace(old, new [, max]) | 把 將字符串中的 str1 替換成 str2,如果 max 指定,則替換不超過 max 次 |
rfind(str, beg=0,end=len(string)) | 類似于 find()函數(shù),不過是從右邊開始查找. |
rindex( str, beg=0, end=len(string)) | 類似于 index(),不過是從右邊開始. |
rjust(width,[, fillchar]) | 返回一個原字符串右對齊,并使用fillchar(默認空格)填充至長度 width 的新字符串 |
rstrip() | 刪除字符串字符串末尾的空格. |
split(str="", num=string.count(str)) | num=string.count(str)) 以 str 為分隔符截取字符串,如果 num 有指定值,則僅截取 num 個子字符串 |
splitlines([keepends]) | 按照行('\r', '\r\n', \n')分隔,返回一個包含各行作為元素的列表,如果參數(shù) keepends 為 False,不包含換行符,如果為 True,則保留換行符 |
startswith(str, beg=0,end=len(string)) | 檢查字符串是否是以 obj 開頭,是則返回 True,否則返回 False,如果beg 和 end 指定值,則在指定范圍內(nèi)檢查。 |
strip([chars]) | 在字符串上執(zhí)行 lstrip()和 rstrip() |
swapcase() | 將字符串中大寫轉(zhuǎn)換為小寫,小寫轉(zhuǎn)換為大寫 |
title() | 返回"標題化"的字符串,就是說所有單詞都是以大寫開始,其余字母均為小寫(見 istitle()) |
translate(table, deletechars="") | 根據(jù) str 給出的表(包含 256 個字符)轉(zhuǎn)換 string 的字符, 要過濾掉的字符放到 deletechars 參數(shù)中 |
upper() | 轉(zhuǎn)換字符串中的小寫字母為大寫 |
zfill (width) | 返回長度為 width 的字符串,原字符串右對齊,前面填充0 |
isdecimal() | 檢查字符串是否只包含十進制字符,如果是返回 true,否則返回 false |