# sort是會(huì)影響列表本身
lis = [4,5,68,46,4,]
lis.sort()
print(lis)
[4, 4, 5, 46, 68]
sorted
dic = {0: 9, 1: 0, 2: 3, 3: 3, 4: 1, 5: 7, 6: 4}
# 將字典items鍵值對組成元組傳入,取每個(gè)元組[1]元素進(jìn)行排序,reverse表示升降序
b = dict(sorted(dic.items(),key=lambda x:x[1],reverse=True))
print(b)
{0: 9, 5: 7, 6: 4, 2: 3, 3: 3, 4: 1, 1: 0}
portfolio = [
{'name': 'IBM', 'shares': 100, 'price': 91.1},
{'name': 'AAPL', 'shares': 50, 'price': 543.22},
{'name': 'FB', 'shares': 200, 'price': 21.09},
{'name': 'HPQ', 'shares': 35, 'price': 31.75},
{'name': 'YHOO', 'shares': 45, 'price': 16.35},
{'name': 'ACME', 'shares': 75, 'price': 115.65}
]
a = sorted([i for i in portfolio],key=lambda x:x['price'],reverse=True)
print(a)
- 模塊
heapq方法
- 傳入三個(gè)參數(shù),
nsmallest(n, iterable, key=None)
-
n -> 排序的數(shù)量
-
iterable -> 要排序的可迭代對象
-
key -> 排序的關(guān)鍵字
import heapq
portfolio = [
{'name': 'IBM', 'shares': 100, 'price': 91.1},
{'name': 'AAPL', 'shares': 50, 'price': 543.22},
{'name': 'FB', 'shares': 200, 'price': 21.09},
{'name': 'HPQ', 'shares': 35, 'price': 31.75},
{'name': 'YHOO', 'shares': 45, 'price': 16.35},
{'name': 'ACME', 'shares': 75, 'price': 115.65}
]
# 升序
cheap = heapq.nsmallest(len(portfolio),portfolio, key=lambda s: s['price'])
print(cheap)
[{'name': 'YHOO', 'price': 16.35, 'shares': 45},
{'name': 'FB', 'price': 21.09, 'shares': 200},
{'name': 'HPQ', 'price': 31.75, 'shares': 35},
{'name': 'IBM', 'price': 91.1, 'shares': 100},
{'name': 'ACME', 'price': 115.65, 'shares': 75},
{'name': 'AAPL', 'price': 543.22, 'shares': 50}]
# 降序
expensive = heapq.nlargest(3, portfolio, key=lambda s: s['price'])
print(expensive)
[{'name': 'AAPL', 'price': 543.22, 'shares': 50},
{'name': 'ACME', 'price': 115.65, 'shares': 75},
{'name': 'IBM', 'price': 91.1, 'shares': 100}]