Python中字典和集合


 

 

Python中字典和集合

映射類型:
    表示一個任意對象的集合,且可以通過另一個幾乎是任意鍵值的集合進行索引
    與序列不同,映射是無序的,通過鍵進行索引
        任何不可變對象都可用作字典的鍵,如字符串、數字、元組等
        包含可變對象的列表、字典和元組不能用作鍵
        引用不存在的鍵會引發KeyError異常

1)字典

    dict    {  }    空字典
            { key1:value1,key2:value2,... } 字典在其它編程語言中又稱作關聯數組或散列表; 通過鍵實現元素存取;無序集合;可變類型容器,長度可變,異構,嵌套 支持的操作: len(D) 返回D中的項目數 D[k] 返回D中鍵k的值 D[k] = x 將D[k]的值設為x >>> d1 = {'x':1,'y':2,'z':3} >>> d1['x'] 1 >>> d1['z'] 通過鍵索引 3 del D[k] 從D中刪除D[k] >>> del d1['x'] >>> d1 {'y': 2, 'z': 3} k in D 如果k是D中的值,則返回True 支持的方法: D.clear() 清除所有元素 D.copy() 復制一個副本 >>> d1 = {'x':1,'y':2,'z':3} >>> id(d1) 45320640 >>> d2 = d1.copy() 深復制 >>> id(d2) 45997776 >>> d3 = d1 淺復制 >>> id(d3) 45320640 d1、d3指向同一對象,d2指向另一對象 D.get(k[,d]) 取得對應鍵的值,若不存在則返回d(默認為空) >>> d1.get('y') 2 D.has_key(k) 是否存在鍵值,返回True或False.(僅在pyhton2中使用) D.items() 轉換為(key,value)元組組成的列表 >>> d1.items() [('y', 2), ('x', 1), ('z', 3)] >>> t1,t2,t3 = d1.items() >>> t1 ('y', 2) >>> t2 ('x', 1) >>> t3 ('z', 3) >>> m1,m2 = {'x':1,'y':2} >>> print m1 'y' >>> print m2 'x' 保存的是鍵,而不是值!!! D.values() 值列表 >>> d1.values() [2, 1, 3] D.keys() 鍵列表 >>> d1.keys() ['y', 'x', 'z'] D.pop(k[,d]) 彈出指定鍵值,若不指定則會觸發異常 >>> d1.pop() TypeError: pop expected at least 1 arguments, got 0 >>> d1.pop('x') 1 >>> d1 {'y': 2, 'z': 3} D.popitem() 隨機彈出 >>> d1.popitem() ('y', 2) >>> d1.popitem() ('z', 3) >>> d1.popitem() KeyError: 'popitem(): dictionary is empty' 為空時異常 >>> d1 { } D.update(m) 合並字典 >>> d1 = { 'x':1,'y':2,'z':3 } >>> d2={'c':'hello','y':66} >>> d1.update(d2) >>> d1 {'y': 66, 'x': 1, 'c': 'hello', 'z': 3} 若鍵存在則會覆蓋,不存在就添加 D.iteritems() 返回一個迭代器對象 >>> d1 = { 'x':1,'y':2,'z':3 } >>> i1 = d1.iteritems() >>> i1.next() 使用next方式遍歷每一個元素 ('y', 2) >>> i1.next() ('x':1) >>> i1.next() ('z':3) >>> i1.next() StopIteration 遍歷結束后不會重新開始 D.iterkeys() -> an iterator over the keys of D >>> i2 = d1.iterkey() >>> i2.next() 'y' D.itervalues() -> an iterator over the values of D >>> i3 = d1.iterkey() >>> i3.next() 2 D.viewvalues() 返回類似集合方式的字典(值組成) >>> d1.viewvalues() dict_values([2, 1, 3]) D.viewitems() -> a set-like object providing a view on D's items(鍵值對) >>> d1.viewitems() dict_items([('y', 2), ('x', 1), ('z', 3)]) D.viewkeys() -> a set-like object providing a view on D's keys >>> d1.viewkeys() dict_keys(['y', 'x', 'z']) >>> d2 = dict(x=1,y=2,z=3) 定義字典另一種方式 >>> d2 {'y': 2, 'x': 1, 'z': 3} 補充:zip 返回元組組成的列表 >>> zip('xyz','123') [('x', '1'), ('y', '2'), ('z', '3')] 一一對應生成列表 >>> zip('xyzm','123') [('x', '1'), ('y', '2'), ('z', '3')] 多余項被舍棄 >>> zip('xyz','123','qer') [('x', '1', 'q'), ('y', '2', 'e'), ('z', '3', 'r')] >>> dict(zip('xyz','123')) 構造字典 {'y': '2', 'x': '1', 'z': '3'} 

2)集合

  無序排列、可哈希;
  支持集合關系測試
        成員關系測試:
            in not in 迭代 不支持:索引、元素獲取、切片 集合的類型: set() frozenset() 可變 不可變 沒有特定語法格式,只能通過工廠函數創建 例: >>> s1=set(1,2,3) TypeError: set expected at most 1 arguments, got 3 錯誤方式 >>> s1 = set([1,2,3]) 正確方式 >>> s1 set([1, 2, 3]) >>> type(s1) set 支持的方法和操作:

3)小結

    如何獲取使用幫助:
        獲取對象支持使用的屬性和方法:dir()
        某方法的具體使用幫助:help(list.pop)
        獲取可調用對象的文檔字串:print obj.__doc__
        
    容器、類型、對象:
        1、列表、元組、字典字面量可在無換行符下分布在多行內,最后一個字符后可跟逗號(若空則不可使用) 2、所有對象都有引用計數(sys模塊中getrefcount方法); >>> import sys >>> s1 set([1, 2, 3]) >>> sys.getrefcount(s1) 查看s1的引用計數 3 3、列表和字典都支持兩種類型的復制操作:淺復制和深復制;深復制可使用copy模塊中的deepcopy()實現。 4、Python中的所有對象都是“第一類的”,這意味着使用標識符命名的所有對象都具有相同狀態,於是,能夠命名所有對象都可以直接當數據進行處理; 5、所有序列都支持迭代;(非負整數的有序集合) 6、所有序列都支持的操作和方法: s[i] 索引 s[i:j] 切片 s[i:j:stride] 擴展切片 len(s) min(s) max(s) sum(s) all(s) 所有為true any(s) 任意為true s1 + s2: 連接 s1 * N: 重復 成員關系判斷: obj in s1 obj not in s1 7、可變序列的操作: s[index] = value 元素賦值 s[i:j] = t 切片賦值 s[i:j:stride] = t 擴展切片賦值 del s[index] 元素刪除 del s[i:j] 切片刪除 del s[i:j:stride] 擴展切片刪除 引用計數和垃圾回收: 所有對象都有引用計數 給對象分配一個新名稱或將其放入一個容器內,其引用計數都會增加 用del語句或為變量重新賦值時,其引用計數會減少 sys.getrefcount()可以獲得對象的當前引用計數 一個對象的引用計數器歸零時,它將被垃圾收集機制回收


免責聲明!

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



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