內置函數就是python給你提供的, 拿來直接用的函數,好比print.,input等。截止到python版本3.6.2 python一共提供了68個內置函數。php
68個內置函數help() min() setattr() abs() dict() all() dir() hex() next() slice() any() divmod() id() object() sorted() ascii() enumerate() input() oct() staticmethod() eval() int() open() str() bin() exec() isinstance() ord() sum() bool() bytearray() filter() issubclass() pow() super() print() tuple() bytes() float() iter() type() callable() format() len() property() chr() frozenset() list() range() vars() classmethod() getattr() locals() repr() zip() compile() globals() map() reversed() __import__() complex() hasattr() max() round() hash() memoryview() set() delattr()
和數字相關python
1. 數據類型nginx
bool : 布爾型(True,False)web
int : 整型(整數)算法
float : 浮點型(小數)shell
complex : 複數swift
2. 進制轉換數組
bin() 將給的參數轉換成二進制瀏覽器
otc() 將給的參數轉換成八進制bash
hex() 將給的參數轉換成十六進制
print(bin(10)) # 二進制:0b1010print(hex(10)) # 十六進制:0xaprint(oct(10)) # 八進制:0o12
3. 數學運算
abs() 返回絕對值
divmode() 返回商和餘數
round() 四捨五入
pow(a, b) 求a的b次冪, 若是有三個參數. 則求完次冪後對第三個數取餘
sum() 求和
min() 求最小值
max() 求最大值
print(abs(-2)) # 絕對值:2print(divmod(20,3)) # 求商和餘數:(6,2)print(round(4.50)) # 五舍六入:4print(round(4.51)) #5print(pow(10,2,3)) # 若是給了第三個參數. 表示最後取餘:1print(sum([1,2,3,4,5,6,7,8,9,10])) # 求和:55print(min(5,3,9,12,7,2)) #求最小值:2print(max(7,3,15,9,4,13)) #求最大值:15
和數據結構相關
1. 序列
(1)列表和元組
list() 將一個可迭代對象轉換成列表
tuple() 將一個可迭代對象轉換成元組
print(list((1,2,3,4,5,6))) #[1, 2, 3, 4, 5, 6]print(tuple([1,2,3,4,5,6])) #(1, 2, 3, 4, 5, 6)
(2)相關內置函數
reversed() 將一個序列翻轉, 返回翻轉序列的迭代器
slice() 列表的切片
lst = "你好啊"it = reversed(lst) # 不會改變原列表. 返回一個迭代器, 設計上的一個規則print(list(it)) #[ 啊 , 好 , 你 ]lst = [1, 2, 3, 4, 5, 6, 7]print(lst[1:3:1]) #[2,3]s = slice(1, 3, 1) # 切片用的print(lst[s]) #[2,3]
(3)字符串
str() 將數據轉化成字符串
print(str(123)+ 456 ) #123456 format() 與具體數據相關, 用於計算各類小數, 精算等.
s = "hello world!"print(format(s, "^20")) #劇中print(format(s, "<20")) #左對齊print(format(s, ">20")) #右對齊# hello world! # hello world! # hello world!print(format(3, b )) # 二進制:11print(format(97, c )) # 轉換成unicode字符:aprint(format(11, d )) # ⼗進制:11print(format(11, o )) # 八進制:13 print(format(11, x )) # 十六進制(⼩寫字母):bprint(format(11, X )) # 十六進制(大寫字母):Bprint(format(11, n )) # 和d⼀樣:11print(format(11)) # 和d⼀樣:11print(format(123456789, e )) # 科學計數法. 默認保留6位小數:1.234568e+08print(format(123456789, 0.2e )) # 科學計數法. 保留2位小數(小寫):1.23e+08print(format(123456789, 0.2E )) # 科學計數法. 保留2位小數(大寫):1.23E+08print(format(1.23456789, f )) # 小數點計數法. 保留6位小數:1.234568print(format(1.23456789, 0.2f )) # 小數點計數法. 保留2位小數:1.23print(format(1.23456789, 0.10f )) # 小數點計數法. 保留10位小數:1.2345678900print(format(1.23456789e+3, F )) # 小數點計數法. 很大的時候輸出INF:1234.567890
bytes() 把字符串轉化成bytes類型
bs = bytes("今天吃飯了嗎", encoding="utf-8")print(bs) #b ä»å¤©åé¥äºå bytearray() 返回一個新字節數組. 這個數字的元素是可變的, 而且每一個元素的值得範圍是[0,256)ret = bytearray("alex" ,encoding = utf-8 )print(ret[0]) #97print(ret) #bytearray(b alex )ret[0] = 65 #把65的位置A賦值給ret[0]print(str(ret)) #bytearray(b Alex )
ord() 輸入字符找帶字符編碼的位置
chr() 輸入位置數字找出對應的字符
ascii() 是ascii碼中的返回該值 不是就返回u
print(ord( a )) # 字母a在編碼表中的碼位:97print(ord( 中 )) # 中 字在編碼表中的位置:20013print(chr(65)) # 已知碼位,求字符是什麼:Aprint(chr(19999)) #丟for i in range(65536): #打印出0到65535的字符 print(chr(i), end=" ")print(ascii("@")) # @
repr() 返回一個對象的string形式
s = "今天吃了%s頓 飯" % 3print(s)#今天# 吃了3頓 飯print(repr(s)) # 原樣輸出,過濾掉轉義字符 無論百分號%# 今天吃了3頓 飯
2. 數據集合
字典:dict 建立一個字典
集合:set 建立一個集合
frozenset() 建立一個凍結的集合,凍結的集合不能進行添加和刪除操做。
3. 相關內置函數
len() 返回一個對象中的元素的個數
sorted() 對可迭代對象進行排序操做 (lamda)
語法:sorted(Iterable, key=函數(排序規則), reverse=False)
Iterable: 可迭代對象
key: 排序規則(排序函數), 在sorted內部會將可迭代對象中的每個元素傳遞給這個函數的參數. 根據函數運算的結果進行排序
reverse: 是不是倒敘. True: 倒敘, False: 正序
lst = [5,7,6,12,1,13,9,18,5]lst.sort() # sort是list裏面的一個方法print(lst) #[1, 5, 5, 6, 7, 9, 12, 13, 18]ll = sorted(lst) # 內置函數. 返回給你一個新列表 新列表是被排序的print(ll) #[1, 5, 5, 6, 7, 9, 12, 13, 18]l2 = sorted(lst,reverse=True) #倒序print(l2) #[18, 13, 12, 9, 7, 6, 5, 5, 1]
#根據字符串長度給列表排序lst = [ one , two , three , four , five , six ]def f(s): return len(s)l1 = sorted(lst, key=f, )print(l1) #[ one , two , six , four , five , three ]
enumerate() 獲取集合的枚舉對象
lst = [ one , two , three , four , five ]for index, el in enumerate(lst,1): # 把索引和元素一塊兒獲取,索引默認從0開始. 能夠更改 print(index) print(el)# 1# one# 2# two# 3# three# 4# four# 5# five
all() 可迭代對象中所有是True, 結果纔是True
any() 可迭代對象中有一個是True, 結果就是True
print(all([1, hello ,True,9])) #Trueprint(any([0,0,0,False,1, good ])) #True
zip() 函數用於將可迭代的對象做爲參數, 將對象中對應的元素打包成一個元組, 而後返回由這些元組組成的列表. 若是各個迭代器的元素個數不一致, 則返回列表長度與最短的對象相同
lst1 = [1, 2, 3, 4, 5, 6]lst2 = [ 醉鄉民謠 , 驢得水 , 放牛班的春天 , 美麗人生 , 辯護人 , 被嫌棄的松子的一輩子 ]lst3 = [ 美國 , 中國 , 法國 , 意大利 , 韓國 , 日本 ]print(zip(lst1, lst1, lst3)) for el in zip(lst1, lst2, lst3): print(el)# (1, 醉鄉民謠 , 美國 )# (2, 驢得水 , 中國 )# (3, 放牛班的春天 , 法國 )# (4, 美麗人生 , 意大利 )# (5, 辯護人 , 韓國 )# (6, 被嫌棄的松子的一輩子 , 日本 )
fiter() 過濾 (lamda)
語法:fiter(function. Iterable)
function: 用來篩選的函數. 在filter中會自動的把iterable中的元素傳遞給function. 而後根據function返回的True或者False來判斷是否保留留此項數據 , Iterable: 可迭代對象
def func(i): # 判斷奇數 return i % 2 == 1 lst = [1,2,3,4,5,6,7,8,9]l1 = filter(func, lst) #l1是迭代器print(l1) #<filter object at 0x000001CE3CA98AC8>print(list(l1)) #[1, 3, 5, 7, 9]
map() 會根據提供的函數對指定序列列作映射(lamda)
語法 : map(function, iterable)
能夠對可迭代對象中的每個元素進行映射. 分別去執行 function
def f(i): return ilst = [1,2,3,4,5,6,7,]it = map(f, lst) # 把可迭代對象中的每個元素傳遞給前面的函數進行處理. 處理的結果會返回成迭代器print(list(it)) #[1, 2, 3, 4, 5, 6, 7]
和做用域相關
locals() 返回當前做用域中的名字
globals() 返回全局做用域中的名字
def func(): a = 10 print(locals()) # 當前做用域中的內容 print(globals()) # 全局做用域中的內容 print("今天內容不少")func() a : 10} { __name__ : __main__ , __doc__ : None, __package__ : None, __loader__ : { <_frozen_importlib_external.SourceFileLoader object at 0x0000026F8D566080>, __spec__ : None, __annotations__ : {}, __builtins__ : <module builtins __file__ : D:/pycharm/練習/week03/new14.py , __cached__ : None, (built-in)>, func : <function func at 0x0000026F8D6B97B8>} 今天內容不少
和迭代器/生成器相關
range() 生成數據
next() 迭代器向下執行一次, 內部實際使⽤用了__ next__()⽅方法返回迭代器的下一個項目
iter() 獲取迭代器, 內部實際使用的是__ iter__()⽅方法來獲取迭代器
for i in range(15,-1,-5): print(i)# 15# 10# 5# 0lst = [1,2,3,4,5]it = iter(lst) # __iter__()得到迭代器print(it.__next__()) #1print(next(it)) #2 __next__() print(next(it)) #3print(next(it)) #4
字符串類型代碼的執行
eval() 執行字符串類型的代碼. 並返回最終結果
exec() 執行字符串類型的代碼
compile() 將字符串類型的代碼編碼. 代碼對象可以經過exec語句來執行或者eval()進行求值
s1 = input("請輸入a+b:") #輸入:8+9print(eval(s1)) # 17 能夠動態的執行代碼. 代碼必須有返回值s2 = "for i in range(5): print(i)"a = exec(s2) # exec 執行代碼不返回任何內容# 0# 1# 2# 3# 4print(a) #None# 動態執行代碼exec("""def func(): print(" 我是周杰倫")""" )func() #我是周杰倫
code1 = "for i in range(3): print(i)"com = compile(code1, "", mode="exec") # compile並不會執行你的代碼.只是編譯exec(com) # 執行編譯的結果# 0# 1# 2code2 = "5+6+7"com2 = compile(code2, "", mode="eval")print(eval(com2)) # 18code3 = "name = input( 請輸入你的名字: )" #輸入:hellocom3 = compile(code3, "", mode="single")exec(com3)print(name) #hello
輸入輸出
print() : 打印輸出
input() : 獲取用戶輸出的內容
print("hello", "world", sep="*", end="@") # sep:打印出的內容用什麼鏈接,end:以什麼爲結尾#hello*world@
內存相關
hash() : 獲取到對象的哈希值(int, str, bool, tuple). hash算法:(1) 目的是惟一性 (2) dict 查找效率很是高, hash表.用空間換的時間 比較耗費內存
s = alex print(hash(s)) #-168324845050430382lst = [1, 2, 3, 4, 5]print(hash(lst)) #報錯,列表是不可哈希的 id() : 獲取到對象的內存地址s = alex print(id(s)) #2278345368944
文件操做相關
open() : 用於打開一個文件, 建立一個文件句柄
f = open( file ,mode= r ,encoding= utf-8 )f.read()f.close()
模塊相關
-
__ import__() : 用於動態加載類和函數
# 讓用戶輸入一個要導入的模塊import osname = input("請輸入你要導入的模塊:")__import__(name) # 能夠動態導入模塊
幫 助
help() : 函數用於查看函數或模塊用途的詳細說明
print(help(str)) #查看字符串的用途
調用相關
callable() : 用於檢查一個對象是不是可調用的. 若是返回True, object有可能調用失敗, 但若是返回False. 那調用絕對不會成功
a = 10print(callable(a)) #False 變量a不能被調用#def f(): print("hello") print(callable(f)) # True 函數是能夠被調用的
查看內置屬性
dir() : 查看對象的內置屬性, 訪問的是對象中的__dir__()方法
print(dir(tuple)) #查看元組的方法
![](http://static.javashuo.com/static/loading.gif)
掃描下方二維碼
加入優質社羣一塊兒交流吧!
如若二維碼過時
請添加小編微信,回覆關鍵詞:[進羣/加羣],
-今日互動-
你學會了嗎?歡迎文章下方留言互動或加入優質社羣共同提升
若是對你有幫助的話
❤️來個「轉發朋友圈」和「在看」,是最大的支持❤️
本文分享自微信公衆號 - DataScience(DataScienceTeam)。
若有侵權,請聯繫 support@oschina.cn 刪除。
本文參與「OSC源創計劃」,歡迎正在閱讀的你也加入,一塊兒分享。