這是一個(gè)系列文章,主要分享python的使用建議和技巧,每次分享3點(diǎn),希望你能有所收獲。
1 如何去掉list中重復(fù)元素
- 推薦方式
my_list = [3, 2, 1, 1, 2, 3]
print my_list
# [3, 2, 1, 1, 2, 3]
unique_list = list(set(my_list))
print unique_list
# [1, 2, 3]
或者
from collections import OrderedDict
my_list = [3, 2, 1, 1, 2, 3]
print my_list
# [3, 2, 1, 1, 2, 3]
unique_list = list(OrderedDict.fromkeys(my_list))
print unique_list
# [3, 2, 1]
前一種方式不會(huì)保留list的元素順序,后一種方式會(huì)保留list的元素順序。
2 如何讀取dict中的值
- 不推薦方式
url_dict = {
'google': 'https://www.google.com/',
'github': 'https://github.com/',
'facebook': 'https://www.facebook.com/',
}
print url_dict['facebook']
print url_dict['google']
print url_dict['github']
# print url_dict['baidu']
# KeyError: 'baidu'
# https://www.facebook.com/
# https://www.google.com/
# https://github.com/
- 推薦方式
url_dict = {
'google': 'https://www.google.com/',
'github': 'https://github.com/',
'facebook': 'https://www.facebook.com/',
}
print url_dict.get('facebook', 'https://www.google.com/')
print url_dict.get('google', 'https://www.google.com/')
print url_dict.get('github', 'https://www.google.com/')
print url_dict.get('baidu', 'https://www.google.com/')
# https://www.facebook.com/
# https://www.google.com/
# https://github.com/
# https://www.google.com/
前一種方式讀取一個(gè)不存在的key時(shí),會(huì)導(dǎo)致KeyError,例如print url_dict['baidu'],因?yàn)樽值渲胁淮嬖赽aidu,所以會(huì)導(dǎo)致KeyError。后一種方式使用字典的get方法,如果key不存在,不會(huì)產(chǎn)生KeyError,如果給了默認(rèn)值,會(huì)返回默認(rèn)值,否則返回None。
3 如何排序字典
- 推薦方式
unordered_dict = {'c': 1, 'b': 2, 'a': 3}
print sorted(unordered_dict.items(), key=lambda e: e[1])
# [('c', 1), ('b', 2), ('a', 3)]
print sorted(unordered_dict.items(), key=lambda e: e[0])
# [('a', 3), ('b', 2), ('c', 1)]
print sorted(unordered_dict.items(), key=lambda e: e[1], reverse=True)
# [('a', 3), ('b', 2), ('c', 1)]
第一種方式是按字典的value升序排序,第二種方式是按字典的key升序排序,第三種方式是按字典的value降序排序,和第一種方式相反,因?yàn)橹付藚?shù)reverse為True。sorted函數(shù)功能挺強(qiáng)大,不止可以排序字典,任何iterable對(duì)象都可以排序,如果想深入了解請(qǐng)戳https://docs.python.org/2.7/howto/sorting.html#sortinghowto。