Python初學(xué)者必須掌握的25個(gè)內(nèi)置函數(shù)詳解
input()
作用:讓用戶從控制臺(tái)輸入一串字符,按下回車后結(jié)束輸入,并返回字符串
注意:很多初學(xué)者以為它可以返回?cái)?shù)字,其實(shí)是錯(cuò)的!
>>> line = input("輸入一個(gè)數(shù)字:")
輸入一個(gè)數(shù)字:1
>>> line
'1' # <-- 看清楚了,這個(gè)不是數(shù)字,只是字符串
# 如果你直接進(jìn)行加法……
>>> line + 1
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: can only concatenate str (not "int") to str
# 正確方法,先把 line 轉(zhuǎn)換成數(shù)字
>>> int(line) + 1
2
print()
作用:把參數(shù)轉(zhuǎn)換成字符串后,輸出到控制臺(tái)
>>> print("hello", "world")
hello world
# 很多人不知道參數(shù)之間還可以插入其他字符
>>> print("hello", "world", sep="~")
hello~world
# 甚至可以讓每個(gè)參數(shù)霸占一行
>>> print("hello", "world", sep="\n")
hello
world
set()
作用:構(gòu)造集合。一個(gè)常用的方法是,把列表傳入 set(),再轉(zhuǎn)成列表,來實(shí)現(xiàn)列表的排重。
>>> set([1, 2, 3, 3])
{1, 2, 3}
# 這樣就實(shí)現(xiàn)了排重
>>> list(set([1, 2, 3, 3]))
[1, 2, 3]
str()
作用:將對象轉(zhuǎn)換成字符串。常用于字符串和數(shù)字的拼接。
例如,這樣會(huì)報(bào)錯(cuò):
>>> 'My Score is: ' + 100 Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: can only concatenate str (not "int") to str
所以要用 str 轉(zhuǎn)換一下:
>>> 'My Score is: ' + str(100) 'My Score is: 100'
chr(i)
作用:返回整數(shù) i 所對應(yīng)的字符,常用于生成字母表。
>>> chr(20013)
'中'
>>> chr(97)
'a'
# 與 ord() 配合,生成字母表
>>> [chr(ord('a') + i) for i in range(26)]
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
ord()
作用:返回字符在編碼表中對應(yīng)的十進(jìn)制數(shù)值
>>> ord('中')
20013
>>> ord('a')
97
# 與 chr() 配合,生成字母表
>>> [chr(ord('a') + i) for i in range(26)]
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
bool()
作用: 判斷一個(gè)對象的布爾值,返回 True 或 False
bool(1) => True bool(0) => False bool([]) => False
說明: 這個(gè)函數(shù)在實(shí)際項(xiàng)目中很少用,只是作為測試工具,讓初學(xué)者能了解各對象的布爾狀態(tài)。
int()
作用: 將任意進(jìn)制的字符串轉(zhuǎn)化為整數(shù)。
int('2') => 2
int('1010', 2) => 10 # 2進(jìn)制1010轉(zhuǎn)化為整數(shù)10
說明: 傳入第2個(gè)參數(shù),可指定參數(shù)1的進(jìn)制類型。
bin()
作用: 把整數(shù)轉(zhuǎn)換成2進(jìn)制的字符串
bin(2) => '0b10' bin(10) => '0b1010'
說明: 為啥字符串前面都有個(gè) 0b ?因?yàn)檫@是標(biāo)準(zhǔn)的寫法,以 0b 開頭表示接下來數(shù)字的是2進(jìn)制。
oct()
作用: 將10進(jìn)制轉(zhuǎn)換為8進(jìn)制的字符串
oct(7) => '0o7' oct(8) => '0o10'
hex()
作用:將10進(jìn)制轉(zhuǎn)換為16進(jìn)制的字符串
>>> hex(11) '0xb' >>> hex(16) '0x10'
abs()
作用:取絕對值
>>> abs(-1) 1
divmod()
作用:同時(shí)返回除法運(yùn)算中的商和余數(shù),相當(dāng)于一次運(yùn)算,同時(shí)得到 a//b 和 a% b 的結(jié)果。
>>> divmod(1, 2) (0, 1) >>> divmod(4, 3) (1, 1)
round()
作用:對一個(gè)浮點(diǎn)數(shù)進(jìn)行四舍五入
>>> round(1.3333) 1 >>> round(1.3333, 2) # 2 表示保留2位小數(shù) 1.33
pow(x, y[, z])
作用:如果只填 x 和 y 參數(shù),則返回 x 的 y 次方。如果填了 z 參數(shù),則再取模,相當(dāng)于 pow(x, y) % z。
>>> pow(10, 2) 100 # 相當(dāng)于 >>> 10**2 100 >>> pow(10, 2, 3) 1 # 相當(dāng)于 >>> 10**2 % 3 1
sum(iterable)
作用:對數(shù)組 iterable 的所有元素進(jìn)行求和。
>>> sum([1, 2, 3]) 6
min(x, y, z, …)
作用:返回所有參數(shù)中的最小數(shù)
>>> min(1, 2, 3) 1 # 傳入數(shù)組也可以 >>> min([1, 2, 3]) 1
max(x, y, z, …)
作用:類似 min(),返回所有參數(shù)中的最大數(shù)
list()
作用:傳入?yún)?shù)為空時(shí),創(chuàng)建列表;傳入?yún)?shù)不為空時(shí),將參數(shù)轉(zhuǎn)換成列表
>>> list()
[]
# 不為空時(shí)
>>> list('hello world')
['h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd']
# 傳入字典試試
>>> list({'a': 1, 'b': 2})
['a', 'b']
tuple()
作用:跟 list 幾乎一模一樣,只不過 list 返回的是數(shù)組,tuple 返回的是元組。
dict()
作用:構(gòu)造字典
# 方法1:
>>> dict(a=1, b=2)
{'a': 1, 'b': 2}
# 方法2:
>>> dict(zip(['a', 'b'], [1, 2]))
{'a': 1, 'b': 2}
# 方法3:
>>> dict([('a', 1), ('b', 2)])
{'a': 1, 'b': 2}
len()
作用:返回對象長度,或元素個(gè)數(shù)
>>> len([1, 2])
2
>>> len({'a': 1, 'b': 2})
2
>>> len('hello')
5
reversed()
作用:反轉(zhuǎn)列表。
注意:返回的不是列表,是個(gè)迭代器。
>>> reversed([1, 2, 3])
<list_reverseiterator object at 0x1016190a0>
# 需要轉(zhuǎn)換成 list
>>> list(reversed([1, 2, 3]))
[3, 2, 1]
# 字符串也一樣
>>> reversed('abc')
<reversed object at 0x1015ffd90>
>>> list(reversed('abc'))
['c', 'b', 'a']
enumerate()
作用:用于遍歷對象,正常的遍歷,比如 for el in array ,只能拿到元素,不能拿到下標(biāo),用 enumerate() 就可以。
>>> for i, el in enumerate('abc'):
... print(i, el)
...
0 a
1 b
2 c
這個(gè)下標(biāo)怎么用呢?比如可以用來反過來修改數(shù)組內(nèi)的元素:
>>> alphabet = ['a', 'b', 'c'] >>> for i, el in enumerate(alphabet): ... alphabet[i] = el.upper() ... >>> alphabet ['A', 'B', 'C']
filter(func, iterable)
作用:過濾并返回符合條件的元素
注意:返回的是一個(gè)迭代器。
>>> alphabet = ['a', 'b', 'c', 'E', 'F', 'G'] >>> filter(lambda e: e.isupper(), alphabet) <filter object at 0x1016190a0> >>> list(filter(lambda e: e.isupper(), alphabet)) ['E', 'F', 'G']
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
- Python內(nèi)置函數(shù)詳談
- python基礎(chǔ)之內(nèi)置函數(shù)
- python高級(jí)內(nèi)置函數(shù)用法實(shí)例
- 10個(gè)使用Python必須知道的內(nèi)置函數(shù)
- Python函數(shù)的作用域及內(nèi)置函數(shù)詳解
- Python隨機(jī)函數(shù)random隨機(jī)獲取數(shù)字、字符串、列表等使用詳解
- Python隨機(jī)函數(shù)庫random的使用方法詳解
- Python隨機(jī)函數(shù)random()使用方法小結(jié)
- python中的隨機(jī)函數(shù)小結(jié)
- Python 內(nèi)置函數(shù)之隨機(jī)函數(shù)詳情
相關(guān)文章
pycharm中import導(dǎo)入包呈現(xiàn)灰色的問題及解決
這篇文章主要介紹了pycharm中import導(dǎo)入包呈現(xiàn)灰色的問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
TensorFlow2中提供的幾種處理特征列的方法小結(jié)
本文主要介紹了TensorFlow2中提供的幾種處理特征列的方法小結(jié),主要介紹了6種方式,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
Python OpenCV機(jī)器學(xué)習(xí)之圖像識(shí)別詳解
OpenCV中也提供了一些機(jī)器學(xué)習(xí)的方法,例如DNN等。本文將為大家詳細(xì)介紹一下OpenCV中利用機(jī)器學(xué)習(xí)實(shí)現(xiàn)的一些圖片識(shí)別功能:人臉識(shí)別、車牌識(shí)別等,感興趣的可以了解一下2022-01-01
Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)同時(shí)對數(shù)據(jù)做轉(zhuǎn)換和換算處理操作示例
這篇文章主要介紹了Python cookbook(數(shù)據(jù)結(jié)構(gòu)與算法)同時(shí)對數(shù)據(jù)做轉(zhuǎn)換和換算處理操作,涉及Python使用生成器表達(dá)式進(jìn)行數(shù)據(jù)處理的相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
python利用elaphe制作二維條形碼實(shí)現(xiàn)代碼
條形碼的應(yīng)用將會(huì)越來越廣泛,看到了一篇文章,寫的挺好的!用手機(jī)拍二維碼,查二維碼確實(shí)很爽!這將成為一種潮流2012-05-05
Python一鍵實(shí)現(xiàn)PDF文檔批量轉(zhuǎn)Word
無論是在工作還是學(xué)習(xí)當(dāng)中,大家都會(huì)遇到這樣一個(gè)問題,將“PDF當(dāng)中的內(nèi)容(文本和圖片)轉(zhuǎn)換為Word的格式”,本文將用Python實(shí)現(xiàn)一鍵批量將PDF轉(zhuǎn)Word,需要的可以參考一下2022-08-08
一篇文章徹底弄懂Python中的if?__name__?==?__main__
在Python當(dāng)中如果代碼寫得規(guī)范一些,通常會(huì)寫上一句if '__name__'=='__main__:'作為程序的入口,下面這篇文章主要給大家介紹了關(guān)于如何通過一篇文章徹底弄懂Python中的if?__name__?==?__main__的相關(guān)資料,需要的朋友可以參考下2022-12-12

