上一篇文章: Python實用技法第6篇:讓字典保持有序
下一篇文章: Python實用技法第8篇:在兩個字典中尋找相同點
咱們想在字典上對數據執行各式各樣的計算,例如:最大值、最小值、排序等
zip()函數用於將可迭代的對象做爲參數,將對象中對應的元素打包成一個個元組,而後返回由這些元組組成的列表。segmentfault
假設有一個字典,在股票名稱和對應價格之間作了映射:函數
prices={ 'ACME':45.23, 'AAPL':612.78, 'IBM':205.55, 'HPQ':37.20, 'FB':10.75 }
爲了能對字典內容作些有用的計算,一般會利用zip()函數將字典的鍵和值反轉過來。code
prices={ 'ACME':45.23, 'AAPL':612.78, 'IBM':205.55, 'HPQ':37.20, 'FB':10.75 } #找出價格最低放入股票 min_price=min(zip(prices.values(),prices.keys())) print(min_price) #找出價格最高放入股票 max_price=max(zip(prices.values(),prices.keys())) print(max_price) #一樣,要對數據排序只要使用zip()再配合sorted() prices_sorted=sorted(zip(prices.values(),prices.keys())) print(prices_sorted)
運行結果:對象
(10.75, 'FB') (612.78, 'AAPL') [(10.75, 'FB'), (37.2, 'HPQ'), (45.23, 'ACME'), (205.55, 'IBM'), (612.78, 'AAPL')]
注意,zip()建立的迭代器只能被消費一次,例以下面排序
zip_price=zip(prices.values(),prices.keys()) min_price=min(zip_price) #ok min_price=min(zip_price) #報錯
上一篇文章: Python實用技法第6篇:讓字典保持有序
下一篇文章: Python實用技法第8篇:在兩個字典中尋找相同點