-參考廖雪峰官網(wǎng)
r=list(range(10))
for i in r:
# print r.pop() #打印出9-5 我很奇怪為什么不能打印到0 結(jié)果在下圖
print i #打印出0-9
r=list(range(10))
print range(len(r))
print r
都是打印出1-10
但是
r=list(range(10))
for i in range(len(r)):
print r.pop() #9-0
r=list(range(10))
for i in r:
print r.pop() # 9-5
r=list(range(10))
for i in range(len(r)):
# print r.pop() #打印出9-0。彈出是從后開(kāi)始彈
print i # 打印出0-9
range(10)
數(shù)組有十個(gè)值,每次應(yīng)該彈出一個(gè),但為什么一直是9呢
有序集合list
,用[]
的方式寫(xiě)集合
list
是一種有序的集合,可以隨時(shí)添加和刪除其中的元素。
這是原數(shù)據(jù)
arr = ['Michael', 'Bob', 'Tracy']
print len(arr) #3 獲取list的長(zhǎng)度
print arr[1] #Bob。 整數(shù)是從0下標(biāo)開(kāi)始的
print arr[-1] #Tracy -1就是最后一個(gè),-2是倒數(shù)第二個(gè)
- 1.list是一個(gè)可變的有序表,所以,可以往list中追加元素到末尾:
print arr.append('Adam') #['Michael', 'Bob', 'Tracy', 'Adam']
- 2.也可以把元素插入到指定的位置,比如索引號(hào)為1的位置:
print arr.insert(1, 'Jack') #['Michael', 'Jack', 'Bob', 'Tracy', 'Adam']
- 3.要?jiǎng)h除list末尾的元素,用pop()方法:
print arr.pop() # ['Michael', 'Bob']
- 4.要?jiǎng)h除指定位置的元素,用pop(i)方法,其中i是索引位置:
print arr.pop(1) #['Michael', 'Tracy']
- 5.要把某個(gè)元素替換成別的元素,可以直接賦值給對(duì)應(yīng)的索引位置:
arr.[1] = 'Sarah'
print arr # ['Michael','Sarah', 'Tracy']
固定集合tuple
,用()
的方式寫(xiě)集合
另一種有序列表叫元組:tuple。tuple和list非常類(lèi)似,但是tuple一旦初始化就不能修改
>>> classmates = ('Michael', 'Bob', 'Tracy')
現(xiàn)在,classmates這個(gè)tuple不能變了,它也沒(méi)有append(),insert()這樣的方法。其他獲取元素的方法和list是一樣的,你可以正常地使用classmates[0],classmates[-1],但不能賦值成另外的元素。
不可變的tuple有什么意義?因?yàn)閠uple不可變,所以代碼更安全。如果可能,能用tuple代替list就盡量用tuple。
- tuple的陷阱:當(dāng)你定義一個(gè)tuple時(shí),在定義的時(shí)候,tuple的元素就必須被確定下
dict
是使用的hash
算法, 使用{}
dict
(字典)全稱(chēng)dictionary
,在其他語(yǔ)言中也稱(chēng)為map
,使用鍵-值(key-value)
存儲(chǔ),具有極快的查找速度。無(wú)論這個(gè)表有多大,查找速度都不會(huì)變慢。
因?yàn)?code>dict的實(shí)現(xiàn)原理和查字典
是一樣的
>>> d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}
>>> d['Michael']
95
-
dict
的特點(diǎn)
1.由于一個(gè)key只能對(duì)應(yīng)一個(gè)value,所以,多次對(duì)一個(gè)key放入value,后面的值會(huì)把前面的值沖掉:
2.如果key不存在,dict就會(huì)報(bào)錯(cuò):
- 要避免key不存在的錯(cuò)誤,有兩種辦法,一是通過(guò)in判斷key是否存在:
>>> 'Thomas' in d
False
二是通過(guò)dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value:
>>> d.get('Thomas') #返回None的時(shí)候Python的交互式命令行不顯示結(jié)果。
>>> d.get('Thomas', -1)
-1
- 要?jiǎng)h除一個(gè)
key
,用pop(key)
方法,對(duì)應(yīng)的value也會(huì)從dict中刪除:
>>> d.pop('Bob')
75
>>> d
{'Michael': 95, 'Tracy': 85}
aa = {'Lisa': 88, 'Adam': 99, 'Bart': 77}
print aa.items() # >>>[('Lisa', 88), ('Adam', 99), ('Bart', 77)]
請(qǐng)務(wù)必注意,
dict內(nèi)部存放的順序
和key放入的順序
是沒(méi)有關(guān)系的。
-
和list比較,dict有以下幾個(gè)特點(diǎn):
- 查找和插入的速度極快,不會(huì)隨著key的增加而變慢;
- 需要占用大量的內(nèi)存,內(nèi)存浪費(fèi)多。
-
而list相反:
查找和插入的時(shí)間隨著元素的增加而增加;
占用空間小,浪費(fèi)內(nèi)存很少。
所以,dict是用空間來(lái)?yè)Q取時(shí)間的一種方法。
所以,dict是用空間來(lái)?yè)Q取時(shí)間的一種方法。
dict可以用在需要高速查找的很多地方,在Python代碼中幾乎無(wú)處不在,正確使用dict非常重要,需要牢記的第一條就是dict的key必須是不可變對(duì)象。
函數(shù)總結(jié)
小結(jié)
Python的函數(shù)具有非常靈活的參數(shù)形態(tài),既可以實(shí)現(xiàn)簡(jiǎn)單的調(diào)用,又可以傳入非常復(fù)雜的參數(shù)。
默認(rèn)參數(shù)一定要用不可變對(duì)象,如果是可變對(duì)象,程序運(yùn)行時(shí)會(huì)有邏輯錯(cuò)誤!
要注意定義可變參數(shù)和關(guān)鍵字參數(shù)的語(yǔ)法:
*args是可變參數(shù),args接收的是一個(gè)tuple;
**kw是關(guān)鍵字參數(shù),kw接收的是一個(gè)dict。
以及調(diào)用函數(shù)時(shí)如何傳入可變參數(shù)和關(guān)鍵字參數(shù)的語(yǔ)法:
可變參數(shù)既可以直接傳入:func(1, 2, 3),又可以先組裝list或tuple,再通過(guò)*args傳入:func(*(1, 2, 3));
關(guān)鍵字參數(shù)既可以直接傳入:func(a=1, b=2),又可以先組裝dict,再通過(guò)**kw傳入:func(**{'a': 1, 'b': 2})。
使用*args和**kw是Python的習(xí)慣寫(xiě)法,當(dāng)然也可以用其他參數(shù)名,但最好使用習(xí)慣用法。
命名的關(guān)鍵字參數(shù)是為了限制調(diào)用者可以傳入的參數(shù)名,同時(shí)可以提供默認(rèn)值。
定義命名的關(guān)鍵字參數(shù)在沒(méi)有可變參數(shù)的情況下不要忘了寫(xiě)分隔符*,否則定義的將是位置參數(shù)。
函數(shù)例子
def hello(greeting, *args):
if (len(args)==0):
print('%s!' % greeting)
else:
print('%s, %s!' % (greeting, ', '.join(args)))
hello('Hi') # => greeting='Hi', args=()
hello('Hi', 'Sarah') # => greeting='Hi', args=('Sarah')
hello('Hello', 'Michael', 'Bob', 'Adam') # => greeting='Hello', args=('Michael', 'Bob', 'Adam')
names = ('Bart', 'Lisa')
hello('Hello', *names) # => greeting='Hello', args=('Bart', 'Lisa')
def print_scores(**kw):
print(' Name Score')
print('------------------')
for name, score in kw.items():
print('%10s %d' % (name, score))
print()
print_scores(Adam=99, Lisa=88, Bart=77)
data = {
'Adam Lee': 99,
'Lisa S': 88,
'F.Bart': 77
}
print_scores(**data)
def print_info(name, *, gender, city='Beijing', age):
print('Personal Info')
print('---------------')
print(' Name: %s' % name)
print(' Gender: %s' % gender)
print(' City: %s' % city)
print(' Age: %s' % age)
print()
print_info('Bob', gender='male', age=20)
print_info('Lisa', gender='female', city='Shanghai', age=18)
- 通過(guò)切片截取字符串
>>> print result
helloworld
>>> print result[1:3]
el
>>> print result[0:3]
hel