01-字符串
1.什么是字符串
使用單引號或者雙引號括起來的字符集就是字符串(字符串是不可變的
)
字符串是不可變的叉存,所以你不能僅僅改變或刪除一個字符串里的某個字符,你能做的是刪除整個字符串,或者是把剔除了不需要的部分后的字符串組合起來形成一個新串
2什么是轉(zhuǎn)義字符
在Python中使用反斜杠符號( \ )來表示轉(zhuǎn)義
轉(zhuǎn)義占一個字符
轉(zhuǎn)義字符 | 描述 |
---|---|
(在行尾時) | 續(xù)行符 |
\ | 反斜杠符號 |
' | 單引號 |
" | 雙引號 |
\a | 響鈴 |
\b | 退格(Backspace) |
\e | 轉(zhuǎn)義 |
\000 | 空 |
\n | 換行 |
\v | 縱向制表符 |
\t | 橫向制表符 |
\r | 回車 |
\f | 換頁 |
\oyy | 八進(jìn)制數(shù)勺三,yy代表的字符,例如:\o12代表換行 |
\xyy | 十六進(jìn)制數(shù)需曾,yy代表的字符吗坚,例如:\x0a代表換行 |
\other | 其它的字符以普通格式輸出 |
2.阻止轉(zhuǎn)義
使用重復(fù)的兩個反斜杠或者raw字符串
顯示三個反斜杠
1.string=r'\\\n2'
print(string)
\\\n2
2.string='\\\\\\n2'
print(string)
\\\n2
3.編碼
Python中字符串的字符編碼是Unicode
ASCII編碼是(8位)1個字節(jié),而Unicode編碼通常是(16位)2個字節(jié)
編碼的目的是讓字符可以存儲在計算機(jī)中
Unicode包括了ASCII呆万,表示世界上所有的語言和符號
編碼轉(zhuǎn)換 chr() 和 ord()
ord:把字符轉(zhuǎn)換成Unicode
chr:把Unicode轉(zhuǎn)換成字符
字符串比較大小的時候商源,從字符開始依次往后比較每個字符的大小,直到遇到字符不一樣為止
比較字符大小的時候谋减,實(shí)質(zhì)比的是他們的編碼的大小
print('abc'>'b')
False
print('a'>'ab')
False
3牡彻、使用三重引號編寫多行字符串塊
使用三引號可以允許一個字符串跨多行書寫,我們有時候稱其為塊字符串出爹。這個形式以三重引號開始(單引號和雙引號都可以)庄吼,并緊跟任意行數(shù)的文本,并且以和開始時同樣的三重引號結(jié)尾严就。
Python把所有在三重引號之內(nèi)的文本收集到一個字符串中总寻,并在代碼換行處嵌入了換行符。這種方式在程序中需要輸入多行文本的任何時候都是很有用的梢为。
三重引號字符串常用于文檔字符串渐行,當(dāng)它出現(xiàn)在文件的特定地點(diǎn)時,會被當(dāng)作注釋一樣的字符串常量铸董。我們也經(jīng)常在開發(fā)的過程中使用三重引號來廢除一些代碼祟印。
02-獲取字符串的字符
1.獲取字符串的長度
len是獲取序列長度的內(nèi)置函數(shù)
length = len('abc\n123')
print(length)
7
2.通過下標(biāo)獲取字符串的某一個字符
字符串中每個字符都對應(yīng)一個索引,可以通過索引獲取固定字符
索引是從0開始的
使用索引運(yùn)算符 [ ] 和切片運(yùn)算符 [ : ] 可以得到子字符串粟害。
string1 ='abc'
print(string1[0])
a
3.獲取字符串中的部分字符(切片)
獲取str4中的python
str4 ='hello python'
print(str4[6:12])
python
print(str4[-6:12])
python
4.獲取整個字符串的內(nèi)容
str4 ='hello python'
print(str4[:])
hello python
5.步長
str4 ='hello python'
print(str4[::4])
hot
6.字符串倒序
print(str4[::-1])
nohtyP loleh
print(str4[:-3:-1])
no
03-字符串運(yùn)算符.
1.字符串的拼接: +
要么都是數(shù)字,要么都是字符串
str5 = 'hello'+' '+'python '
print(str5)
hello python
2.字符串重復(fù) :*
str6=str5*5
print(str6)
hello python hello python hello python hello python hello python
3. in , not in
字符串1 in 字符串 2:判斷在就是True 不在就是False
result = 'a' in 'abc'
print(result)
True
格式化字符串
符 號 | 描述 |
---|---|
%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é)計數(shù)法格式化浮點(diǎn)數(shù) |
%E | 作用同%e,用科學(xué)計數(shù)法格式化浮點(diǎn)數(shù) |
%g | %f和%e的簡寫 |
%G | %f 和 %E 的簡寫 |
%p | 用十六進(jìn)制數(shù)格式化變量的地址 |
s8 = '%s 最喜歡的十進(jìn)制數(shù)是:%d,\
八進(jìn)制數(shù)字是:0o%o,最喜歡的十六進(jìn)制數(shù): 0x%x,
最喜歡的字母是:%c '%('小明',10,10,10,65)
print(s8)
小明 最喜歡的十進(jìn)制數(shù)是:10,八進(jìn)制數(shù)字是:0o12,最喜歡的十六進(jìn)制數(shù): 0xa ,最喜歡的字母是:A
04-字符串相關(guān)方法
序號 | 方法 | 描述 |
---|---|---|
1 |
capitalize() | 將字符串的第一個字符轉(zhuǎn)換為大寫 |
2 |
center(width, fillchar) | 返回一個指定的寬度 width 居中的字符串悲幅,fillchar 為填充的字符套鹅,默認(rèn)為空格驻襟。 |
3 |
count(str, beg= 0,end=len(string)) | 返回 str 在 string 里面出現(xiàn)的次數(shù),如果 beg 或者 end 指定則返回指定范圍內(nèi) str 出現(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, beg=0, end=len(string)) | 檢查字符串是否以 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锅棕。 |
05-if,else,elif語句
根據(jù)Python的縮進(jìn)規(guī)則拙泽,如果if語句判斷是True,
就把縮進(jìn)語句執(zhí)行裸燎,否則顾瞻,什么也不做。
if語句執(zhí)行有個特點(diǎn)德绿,它是從上往下判斷荷荤,如果在某個判斷上是True,
把該判斷對應(yīng)的語句執(zhí)行后移稳,就忽略掉剩下的elif和else
if <條件判斷1>:
<執(zhí)行1>
elif <條件判斷2>:
<執(zhí)行2>
elif <條件判斷3>:
<執(zhí)行3>
else:
<執(zhí)行4>
只要x是非零數(shù)值蕴纳、非空字符串、非空list等个粱,就判斷為True古毛,否則為False。
練習(xí)
小明身高1.75,體重80.5kg稻薇。請根據(jù)BMI公式(體重除以身高的平方)幫小明計算他的BMI指數(shù)嫂冻,并根據(jù)BMI指數(shù):
低于18.5:過輕
18.5-25:正常
25-28:過重
28-32:肥胖
高于32:嚴(yán)重肥胖
用if-elif判斷并打印結(jié)果:
h = input('請輸入你的身高,按回車鍵確認(rèn)(單位cm):')
height = float(h)/100
w = input('請輸入你的體重塞椎,按回車鍵確認(rèn)(單位kg):')
weight = float(w)
bmi = weight/height/height
if bmi <18.5:
print('你的bmi=',bmi,'體重過輕')
elif bmi <=25:
print('你的bmi=',bmi,'體重正常')
elif bmi <=28:
print('你的bmi=',bmi,'體重過重')
elif bmi <=32:
print('你的bmi=',bmi,'體重肥胖')
else:
print('你的bmi=',bmi,'嚴(yán)重肥胖')