python中有許多內(nèi)置函數(shù)泡仗,不像print
那么廣為人知埋虹,但它們卻異常的強大,用好了可以大大提高代碼效率娩怎。
這次來梳理下8個好用的python內(nèi)置函數(shù)搔课。
1、set()
當(dāng)需要對一個列表進行去重操作的時候截亦,set()
函數(shù)就派上用場了爬泥。
obj = ['a','b','c','b','a']
print(set(obj))
# 輸出:{'b', 'c', 'a'}
set([iterable])
用于創(chuàng)建一個集合,集合里的元素是無序且不重復(fù)的崩瓤。
集合對象創(chuàng)建后袍啡,還能使用并集、交集却桶、差集功能境输。
A = set('hello')
B = set('world')
A.union(B) # 并集,輸出:{'d', 'e', 'h', 'l', 'o', 'r', 'w'}
A.intersection(B) # 交集颖系,輸出:{'l', 'o'}
A.difference(B) # 差集嗅剖,輸出:{'d', 'r', 'w'}
2、eval()
之前有人問如何用python寫一個四則運算器嘁扼,輸入字符串公式窗悯,直接產(chǎn)生結(jié)果。
用eval()
來做就很簡單:
eval(str_expression)
作用是將字符串轉(zhuǎn)換成表達式偷拔,并且執(zhí)行蒋院。
a = eval('[1,2,3]')
print(type(a))
# 輸出:<class 'list'>
b = eval('max([2,4,5])')
print(b)
# 輸出: 5
3、sorted()
在處理數(shù)據(jù)過程中莲绰,我們經(jīng)常會用到排序操作欺旧,比如將列表、字典蛤签、元組里面的元素正/倒排序辞友。
這時候就需要用到sorted()
,它可以對任何可迭代對象進行排序震肮,并返回列表称龙。
對列表升序操作:
a = sorted([2,4,3,7,1,9])
print(a)
# 輸出:[1, 2, 3, 4, 7, 9]
對元組倒序操作:
sorted((4,1,9,6),reverse=True)
print(a)
# 輸出:[9, 6, 4, 1]
使用參數(shù):key,根據(jù)自定義規(guī)則戳晌,按字符串長度來排序:
chars = ['apple','watermelon','pear','banana']
a = sorted(chars,key=lambda x:len(x))
print(a)
# 輸出:['pear', 'apple', 'banana', 'watermelon']
根據(jù)自定義規(guī)則鲫尊,對元組構(gòu)成的列表進行排序:
tuple_list = [('A', 1,5), ('B', 3,2), ('C', 2,6)]
# key=lambda x: x[1]中可以任意選定x中可選的位置進行排序
a = sorted(tuple_list, key=lambda x: x[1])
print(a)
# 輸出:[('A', 1, 5), ('C', 2, 6), ('B', 3, 2)]
4、reversed()
如果需要對序列的元素進行反轉(zhuǎn)操作沦偎,reversed()
函數(shù)能幫到你疫向。
reversed()
接受一個序列咳蔚,將序列里的元素反轉(zhuǎn),并最終返回迭代器搔驼。
a = reversed('abcde')
print(list(a))
# 輸出:['e', 'd', 'c', 'b', 'a']
b = reversed([2,3,4,5])
print(list(b))
# 輸出:[5, 4, 3, 2]
5谈火、map()
做文本處理的時候,假如要對序列里的每個單詞進行大寫轉(zhuǎn)化操作舌涨。
這個時候就可以使用map()
函數(shù)糯耍。
chars = ['apple','watermelon','pear','banana']
a = map(lambda x:x.upper(),chars)
print(list(a))
# 輸出:['APPLE', 'WATERMELON', 'PEAR', 'BANANA']
map()
會根據(jù)提供的函數(shù),對指定的序列做映射囊嘉,最終返回迭代器谍肤。
也就是說map()
函數(shù)會把序列里的每一個元素用指定的方法加工一遍,最終返回給你加工好的序列哗伯。
舉個例子荒揣,對列表里的每個數(shù)字作平方處理:
nums = [1,2,3,4]
a = map(lambda x:x*x,nums)
print(list(a))
# 輸出:[1, 4, 9, 16]
6、reduce()
前面說到對列表里的每個數(shù)字作平方處理焊刹,用map()
函數(shù)系任。
那我想將列表里的每個元素相乘,該怎么做呢虐块?
這時候用到reduce()
函數(shù)俩滥。
from functools import reduce
nums = [1,2,3,4]
a = reduce(lambda x,y:x*y,nums)
print(a)
# 輸出:24
reduce()
會對參數(shù)序列中元素進行累積。
第一贺奠、第二個元素先進行函數(shù)操作霜旧,生成的結(jié)果再和第三個元素進行函數(shù)操作,以此類推儡率,最終生成所有元素累積運算的結(jié)果挂据。
再舉個例子,將字母連接成字符串儿普。
from functools import reduce
chars = ['a','p','p','l','e']
a = reduce(lambda x,y:x+y,chars)
print(a)
# 輸出:apple
你可能已經(jīng)注意到崎逃,reduce()
函數(shù)在python3里已經(jīng)不再是內(nèi)置函數(shù),而是遷移到了functools
模塊中眉孩。
這里把reduce()
函數(shù)拎出來講个绍,是因為它太重要了。
7浪汪、filter()
一些數(shù)字組成的列表巴柿,要把其中偶數(shù)去掉,該怎么做呢死遭?
nums = [1,2,3,4,5,6]
a = filter(lambda x:x%2!=0,nums)
print(list(a))
# 輸出:[1,3,5]
filter()
函數(shù)輕松完成了任務(wù)广恢,它用于過濾序列,過濾掉不符合條件的元素殃姓,返回一個迭代器對象袁波。
filter()
函數(shù)和map()
、reduce()
函數(shù)類似蜗侈,都是將序列里的每個元素映射到函數(shù)篷牌,最終返回結(jié)果。
我們再試試踏幻,如何從許多單詞里挑出包含字母w
的單詞枷颊。
chars = chars = ['apple','watermelon','pear','banana']
a = filter(lambda x:'w' in x,chars)
print(list(a))
# 輸出:['watermelon']
8、enumerate()
這樣一個場景该面,同時打印出序列里每一個元素和它對應(yīng)的順序號夭苗,我們用enumerate()
函數(shù)做做看。
chars = ['apple','watermelon','pear','banana']
for i,j in enumerate(chars):
print(i,j)
'''
輸出:
0 apple
1 watermelon
2 pear
3 banana
'''
enumerate
翻譯過來是枚舉隔缀、列舉的意思题造,所以說enumerate()
函數(shù)用于對序列里的元素進行順序標注,返回(元素猾瘸、索引)組成的迭代器界赔。
再舉個例子說明,對字符串進行標注牵触,返回每個字母和其索引淮悼。
a = enumerate('abcd')
print(list(a))
# 輸出:[(0, 'a'), (1, 'b'), (2, 'c'), (3, 'd')]