條件if else
age = 20
if age > 18:
print('your age is :', age)
print('adult')
根據(jù)Python的縮進(jìn)規(guī)則,如果if語(yǔ)句判斷是True矾缓,就把縮進(jìn)的兩行print語(yǔ)句執(zhí)行了怀酷,否則,什么也不做而账。
結(jié)合使用input()獲取用戶輸入
age = input('請(qǐng)輸入年齡:')
age = int(age)
if age > 18:
print('your age is :', age)
print('adult')
** 注意:因?yàn)閕nput()返回的數(shù)據(jù)類型是str胰坟,str不能直接和整數(shù)比較,必須先把str轉(zhuǎn)換成整數(shù)泞辐。Python提供了int()函數(shù)來完成這件事情:**
- 完整的if else結(jié)構(gòu)
if <條件判斷1>:
<執(zhí)行1>
elif <條件判斷2>:
<執(zhí)行2>
elif <條件判斷3>:
<執(zhí)行3>
else:
<執(zhí)行4>
if判斷條件還可以簡(jiǎn)寫笔横,比如寫:
if x:
print('True')
只要x是非零數(shù)值、非空字符串咐吼、非空l(shuí)ist等吹缔,就判斷為True,否則為False锯茄。
循環(huán)
- for ... in
names = ['Michael', 'Bob', 'Tracy']
for name in names:
print(name)
for x in ...循環(huán)就是把每個(gè)元素代入變量x厢塘,然后執(zhí)行縮進(jìn)塊的語(yǔ)句
Python提供一個(gè)range()函數(shù)生成一個(gè)整數(shù)序列,再通過list()函數(shù)可以轉(zhuǎn)換為list肌幽。比如range(5)生成的序列是從0開始小于5的整數(shù):
>>> list(range(5))
[0,1,2,3,4]
要計(jì)算1-100的整數(shù)之和
sum = 0
for x in range(101):
sum = sum + x
print(sum)
- while循環(huán)
sum = 0
n = 99
while n > 0:
sum = sum + n
n = n - 2
print(sum)
- break語(yǔ)句可以提前退出循環(huán)
- continue語(yǔ)句晚碾,跳過當(dāng)前的這次循環(huán),直接開始下一次循環(huán)
n = 0
while n < 10:
n = n + 1
if n % 2 == 0: # 如果n是偶數(shù)喂急,執(zhí)行continue語(yǔ)句
continue # continue語(yǔ)句會(huì)直接繼續(xù)下一輪循環(huán)格嘁,后續(xù)的print()語(yǔ)句不會(huì)執(zhí)行
print(n)
dict:
dict全稱dictionary,在其他語(yǔ)言中也稱為map廊移,使用鍵-值(key-value)存儲(chǔ)糕簿,具有極快的查找速度
d={'michael' : 95, 'bob' : 75, 'tracy' :85}
print(d['michael']) // 95
- 判斷key是否存在的方法:
- in
>>>'Thomas' in d // False
- 通過dict提供的get()方法,如果key不存在狡孔,可以返回None懂诗,或者自己指定的value:
>>>d.get('Thomas') // none
>>>d.get('Thomas', -1) // -1
注意:返回None的時(shí)候Python的交互式命令行不顯示結(jié)果。
要?jiǎng)h除一個(gè)key苗膝,用pop(key)方法殃恒,對(duì)應(yīng)的value也會(huì)從dict中刪除:
>>> d.pop('bob')
75
>>> d
{'michael' : 95, 'tracy' :85}
和list比較,dict有以下幾個(gè)特點(diǎn):查找和插入的速度極快,不會(huì)隨著key的增加而變慢离唐;需要占用大量的內(nèi)存隆嗅,內(nèi)存浪費(fèi)多。
而list相反:查找和插入的時(shí)間隨著元素的增加而增加侯繁;占用空間小,浪費(fèi)內(nèi)存很少泡躯。
dict的key必須是不可變對(duì)象
在Python中贮竟,字符串、整數(shù)等都是不可變的较剃,因此咕别,可以放心地作為key。而list是可變的写穴,就不能作為key
set
set和dict類似惰拱,也是一組key的集合,但不存儲(chǔ)value啊送。由于key不能重復(fù)偿短,所以,在set中馋没,沒有重復(fù)的key昔逗。
要?jiǎng)?chuàng)建一個(gè)set,需要提供一個(gè)list作為輸入集合
>>> s = set([1,2,3])
>>> s
{1,2,3}
注意篷朵,傳入的參數(shù)[1, 2, 3]是一個(gè)list勾怒,而顯示的{1, 2, 3}只是告訴你這個(gè)set內(nèi)部有1,2声旺,3這3個(gè)元素笔链,顯示的順序也不表示set是有序的。
重復(fù)元素在set中自動(dòng)被過濾:
- 通過add(key)方法可以添加元素到set中腮猖,可以重復(fù)添加鉴扫,但不會(huì)有效果
- 通過remove(key)方法可以刪除元素
>>> s.add(4)
>>> s
{1,2,3,4}
>>>s.remove(3)
>>>s
{1,2,4}
set可以看成數(shù)學(xué)意義上的無序和無重復(fù)元素的集合
- set和dict的唯一區(qū)別僅在于沒有存儲(chǔ)對(duì)應(yīng)的value,但是缚够,set的原理和dict一樣幔妨,所以,同樣不可以放入可變對(duì)象谍椅,因?yàn)闊o法判斷兩個(gè)可變對(duì)象是否相等误堡,也就無法保證set內(nèi)部“不會(huì)有重復(fù)元素”
- 對(duì)于可變對(duì)象,比如list雏吭,對(duì)list進(jìn)行操作锁施,list內(nèi)部的內(nèi)容是會(huì)變化的
>>> a = ['c', 'b', 'a']
>>> a.sort()
>>> a
['a', 'b', 'c']
- 而對(duì)于不可變對(duì)象,比如str,對(duì)str操作是不會(huì)改變?cè)璼tr的內(nèi)容
>>> a = 'abc'
>>> a.replace('a', 'A')
'Abc'
>>> a
'abc'
對(duì)于不變對(duì)象來說悉抵,調(diào)用對(duì)象自身的任意方法肩狂,也不會(huì)改變?cè)搶?duì)象自身的內(nèi)容。相反姥饰,這些方法會(huì)創(chuàng)建新的對(duì)象并返回傻谁,這樣,就保證了不可變對(duì)象本身永遠(yuǎn)是不可變的列粪。