兩種循環(huán)
1.for...in循環(huán)
nums = ['0000', '1111', '2222']
for num in nums:
print(num)
2.while循環(huán)
sum = 0
n = 100
while n > 0:
sum = sum + n
n = n - 1
print(sum)
break語句可以在循環(huán)過程中直接退出循環(huán)讼昆,而continue語句可以提前結(jié)束本輪循環(huán)耳胎,并直接開始下一輪循環(huán)汰寓。
dict字典
people = {'Jerry': 21, 'Tom': 25, 'Tony': 47}
print(people['Jerry'])
people['Tom']=28 #設(shè)置鍵值
print(people['Tom']) #28
print('kelly' in people) #判斷Key是否存在print(d.get('Thomas')) false
print(people.get('kelly')) #判斷Key是否存在 不存在返回none或者自己指定的value none
print(people.get('kelly',-2)) #不存在返回自己指定的value -2
people.pop('Tom') #刪除一個(gè)key
print(people) # {'Jerry': 21, 'Tony': 47}
dict全稱dictionary潭辈,在其他語言中稱為map奸攻,使用鍵-值(key-value)存儲(chǔ)准潭,優(yōu)點(diǎn)是具有極快的查找速度她君。
注意:dict內(nèi)部存放的順序和key放入的順序是沒有關(guān)系的
和list比較静稻,dict有以下幾個(gè)特點(diǎn):
1.查找和插入的速度極快警没,不會(huì)隨著key的增加而變慢;
2.需要占用大量的內(nèi)存振湾,內(nèi)存浪費(fèi)多杀迹。
而list相反:
1.查找和插入的時(shí)間隨著元素的增加而增加;
2.占用空間小押搪,浪費(fèi)內(nèi)存很少树酪。
所以浅碾,dict是用空間來換取時(shí)間的一種方法。
set
set和dict類似续语,也是一組key的集合垂谢,不存儲(chǔ)value,并且key值不能重復(fù)疮茄。
s = set([1, 2, 3,4,5,4,3,4,2,1])
print(s) #{1, 2, 3, 4, 5}
add(key)添加元素
s.add('55')
print(s) #{1, 2, 3, 4, 5, '55'}
remove(key)刪除元素
s.remove(4)
print(s) #{1, 2, 3, 5, '55'}
函數(shù)
print(abs(-22)) # 絕對(duì)值 22
函數(shù)
定義一個(gè)函數(shù)要使用def語句滥朱,依次寫出函數(shù)名、括號(hào)力试、括號(hào)中的參數(shù)和冒號(hào):徙邻,然后,在縮進(jìn)塊中編寫函數(shù)體懂版,函數(shù)的返回值用return語句返回鹃栽。
demo:
def my_abs(x):
if not isinstance(x, (int, float)):
raise TypeError('bad operand type')
if x >= 0:
return x
else:
return -x
print(my_abs(777)) #777
print(my_abs(-999)) #999
def calc(numbers): #參數(shù)
sum = 0
for n in numbers:
sum = sum + n * n
return sum
print(calc([2,5,7,9,4])) #計(jì)算a*a+b*b+...的和
def calc(*numbers): #*表示可變參數(shù)躏率,可以不傳
sum = 0
for n in numbers:
sum = sum + n * n
return sum
print(calc(22,6,7,8,9,10)) #814
print(calc()) #0
迭代
for i, value in enumerate(['A', 'B', 'C']):
print(value)