【python筆記】python中的list、tuple、set、dict用法簡析


list

list是一種有序的集合(或稱作列表),可以很方便地添加和刪除其中的元素。

>>> classmates = ['Michael', 'Bob', 'Tracy']

可通過序號訪問各元素,序號范圍:-n ~ n-1,當索引超出了范圍時,Python會報一個IndexError錯誤

append(...)新增元素:classmates.append('Miranda')

insert(... , ...)插入元素到指定位置:classmates.insert(2,'John')

pop()刪除末尾元素:classmates.pop()

pop(...)刪除指定位置的元素:classmates.pop(1)

remove(...)刪除指定值第一次出現的位置所在元素:classmates.remove('Bob')

count(...)統計指定值出現的次數:classmates.count('Bob')

 

要把某個元素替換成別的元素,可以直接賦值給對應的索引位置:

>>> classmates[1] = 'Sarah'

list的元素的數據類型可以不同,比如:

>>> L = ['Apple', 123, True]

list元素也可以是另一個list,比如: 

>>> s = ['python', 'java', ['asp', 'php'], 'scheme'] >>> len(s) 4

>>> s[2][1] 'asp'

  

tuple

tuple也是一種有序列表,和list非常相似,但是tuple一旦初始化就不能再修改,有點像C++const類型修飾的變量。

 

>>> classmates = ('Michael', 'Bob', 'Tracy') >>> classmates = tuple(['Michael', 'Bob', 'Tracy']) >>> hello = ('hello')

 因為不能再修改,因此沒有append(),insert(),pop()這樣的方法。

當你定義一個tuple時,在定義的時候,tuple的元素就必須被確定下來。兩種特殊的定義:

 

>>> t = ()   # empty tuple

>>> t = (1,)  # tuple with only one element, ',' is necessary

  

 

一種看似可以修改的tuple

 

>>> t = ('a', 'b', ['A', 'B']) >>> t[2][0] = 'X'

>>> t ('a', 'b', ['X', 'B'])

 

表面上看,tuple的元素確實變了,但其實變的不是tuple的元素,而是list的元素。tuple一開始指向的list並沒有改成別的list,所以,tuple所謂的“不變”是說,tuple的每個元素,指向永遠不變。即指向'a',就不能改成指向'b',指向一個list,就不能改成指向其他對象,但指向的這個list本身是可變的!

 

如果在某種特殊情況下,就是想修改tuple的非list元素,比如希望將上面的t修改為('1','b',['A','B']),可先轉換為list然后再修改,最后轉回到tuple:

 

>>> tl = list(t) >>> tl[0] = '1'

>>> t = tuple(tl)

 

 

Set

set是只由關鍵字組成的集合,key不重復且區分大小寫。key必須是不可變對象int,float,bool,str,tuple

.add(key):添加元素key到集合中,可重復添加但是不會有效果

.remove(key):刪除指定key的元素

兩個set可以做交集、並集操作:

 

>>> s1={1,2,3} >>> s2={2,3,4} >>> s1 & s2 {2, 3} >>> s1 | s2 {1, 2, 3, 4} >>> s1 ^ s2 {1, 4} >>> s1 - s2 {1}

 

 

dict

python內置的字典類型,全稱dictionary,相當於C++中的stl::map,使用鍵值對存儲,具備極快的查找速度。可以看作是二元組組成的集合。

比如我們想建立“姓名-成績”映射表: 

>>> d = {'Michael': 95, 'Bob': 75, 'Tracy': 85} >>> d['Michael'] 95

 

一個key只能對應一個value,所以多次對一個key放入value,后面的值會把前面的值覆蓋。且key必須是不可變對象,如果是字符串時區分大小寫。

判斷'Thomas' 是否存在: 

>>> 'Thomas' in d    # 方式1
False >>> d.has_key('Thomas')   # 方式2
False >>> d.get('Thomas', -1)     # 方式3
-1

  

.pop(key):刪除關鍵字為key的元素

.keys():返回key的列表

.values():返回value的列表

.items():返回(key, value)的二元組列表

   ——以上三個函數在名字前面加上iter不用生成新的list,遍歷時推薦使用這種方式,比較節省內存。.iterkeys(). 

.clear():清空字典

.has_key(key):判斷字典中是否有關鍵字key

.update([b]):用字典b更新當前字典,存在則修改,不存在則添加.

 

附:對dict()中的內容進行排序(一般使用較多的是按照value排序,比如成績排序)

 

>>> dic = {'ah' : 87, 'yf' : 96, 'pd' : 89} >>> sorted(dic.iteritems(), key=lambda x:x[1], reverse=True) [('yf', 96), ('pd', 89), ('ah', 87)]

 

其中,此處x:x[1]為設置成按value排序,改為x:x[0]即可實現按關鍵字key排序,還可改為x:(x[1],x[0])表示優先以x[1]為比較對象排序,如果x[1]相等,則以x[0]比較進行排序;reverse設置為True表示降序

 

 

 

轉載請注明出處:http://www.cnblogs.com/webary/p/5187217.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM