Python這68個內建函數,建議你吃透!
python影片教學欄目的給大家頭陣介紹68個內建函數!
內建函數就是Python給你提供的,拿來直接用的函數,例如print,輸入等。
先到python版本3.6.2 ,總共提供了68個內建函數,具體如下
abs() dict() help() min() setattr() all() dir() hex() next() slice() any() pmod() id() object() sorted() ascii() enumerate() input() oct() staticmethod() bin() eval() int() open() str() bool() exec() isinstance() ord() sum() bytearray() filter() issubclass() pow() super() bytes() float() iter() print() tuple() callable() format() len() property() type() chr() frozenset() list() range() vars() classmethod() getattr() locals() repr() zip() compile() globals() map() reversed() __import__() complex() hasattr() max() round() delattr() hash() memoryview() set()复制代码
句子將這68個內建函數綜合整理為12大類,正在學習Python基礎的讀者一定不要錯過,建議收藏學習
與數字相關
1.資料型別
2.轉換轉換
3.數學侵犯
和資料結構相關
#1.序列
2.資料集合
3.相關內建函數
和作用域相關
#和迭代器產生器相關
- ##字符字元字串類型代碼的執行
- 輸入輸出
- #記憶體相關 ##檔案操作相關
- 模組相關
- 幫助
- 呼叫相關
- #查看內建屬性
- 與數字相關
1.資料型別
##bool : 布林型(True,False)
- int : 整數(整數)
- float : 浮點型(小數)
- complex : 複數
- 2.轉換轉換
bin() 將給的參數轉換成二進位
- otc() 將給的參數轉換成八進位
- hex() 將給的參數轉換成十六進位
print(bin(10)) # 二进制:0b1010 print(hex(10)) # 十六进制:0xa print(oct(10)) # 八进制:0o12复制代码
abs() 傳回絕對值
- pmode() 回傳商數
- round() 四捨五入
- #pow(a, b) 求a的b次冪,如果有三個參數。則求完次方後對第三個數取餘
- sum() 求和
- #min() 求簡單
- max() 求頂點
print(abs(-2)) # 绝对值:2 print(pmod(20,3)) # 求商和余数:(6,2) print(round(4.50)) # 五舍六入:4 print(round(4.51)) #5 print(pow(10,2,3)) # 如果给了第三个参数. 表示最后取余:1 print(sum([1,2,3,4,5,6,7,8,9,10])) # 求和:55 print(min(5,3,9,12,7,2)) #求最小值:2 print(max(7,3,15,9,4,13)) #求最大值:15复制代码
#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)复制代码
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]复制代码
- 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' )) # 二进制:11 print(format(97, 'c' )) # 转换成unicode字符:a print(format(11, 'd' )) # ⼗进制:11 print(format(11, 'o' )) # 八进制:13 print(format(11, 'x' )) # 十六进制(⼩写字母):b print(format(11, 'X' )) # 十六进制(大写字母):B print(format(11, 'n' )) # 和d⼀样:11 print(format(11)) # 和d⼀样:11 print(format(123456789, 'e' )) # 科学计数法. 默认保留6位小数:1.234568e+08 print(format(123456789, '0.2e' )) # 科学计数法. 保留2位小数(小写):1.23e+08 print(format(123456789, '0.2E' )) # 科学计数法. 保留2位小数(大写):1.23E+08 print(format(1.23456789, 'f' )) # 小数点计数法. 保留6位小数:1.234568 print(format(1.23456789, '0.2f' )) # 小数点计数法. 保留2位小数:1.23 print(format(1.23456789, '0.10f')) # 小数点计数法. 保留10位小数:1.2345678900 print(format(1.23456789e+3, 'F')) # 小数点计数法. 很大的时候输出INF:1234.567890复制代码
- bytes() 把字符串转化成bytes类型
bs = bytes("今天吃饭了吗", encoding="utf-8") print(bs) #b'\xe4\xbb\x8a\xe5\xa4\xa9\xe5\x90\x83\xe9\xa5\xad\xe4\xba\x86\xe5\x90\x97'复制代码
- bytearray() 返回一个新字节数组. 这个数字的元素是可变的, 并且每个元素的值得范围是[0,256)
ret = bytearray("alex" ,encoding ='utf-8') print(ret[0]) #97 print(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在编码表中的码位:97 print(ord('中')) # '中'字在编码表中的位置:20013 print(chr(65)) # 已知码位,求字符是什么:A print(chr(19999)) #丟 for i in range(65536): #打印出0到65535的字符 print(chr(i), end=" ") print(ascii("@")) #'@'复制代码
- repr() 返回一个对象的string形式
s = "今天\n吃了%s顿\t饭" % 3 print(s)#今天# 吃了3顿 饭 print(repr(s)) # 原样输出,过滤掉转义字符 \n \t \r 不管百分号% #'今天\n吃了3顿\t饭'复制代码
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])) #True print(any([0,0,0,False,1,'good'])) #True复制代码
- zip() 函数用于将可迭代的对象作为参数, 将对象中对应的元素打包成一个元组, 然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致, 则返回列表长度与最短的对象相同
lst1 = [1, 2, 3, 4, 5, 6] lst2 = ['醉乡民谣', '驴得水', '放牛班的春天', '美丽人生', '辩护人', '被嫌弃的松子的一生'] lst3 = ['美国', '中国', '法国', '意大利', '韩国', '日本'] print(zip(lst1, lst1, lst3)) #<zip object at 0x00000256CA6C7A88> 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 i lst = [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' # (built-in)>, '__file__': 'D:/pycharm/练习/week03/new14.py', '__cached__': None, # 'func': <function func at 0x0000026F8D6B97B8>} # 今天内容很多复制代码
和迭代器生成器相关
- range() 生成数据
- next() 迭代器向下执行一次, 内部实际使用了__ next__()方法返回迭代器的下一个项目
- iter() 获取迭代器, 内部实际使用的是__ iter__()方法来获取迭代器
for i in range(15,-1,-5): print(i) # 15 # 10 # 5 # 0 lst = [1,2,3,4,5] it = iter(lst) # __iter__()获得迭代器 print(it.__next__()) #1 print(next(it)) #2 __next__() print(next(it)) #3 print(next(it)) #4复制代码
字符串类型代码的执行
- eval() 执行字符串类型的代码. 并返回最终结果
- exec() 执行字符串类型的代码
- compile() 将字符串类型的代码编码. 代码对象能够通过exec语句来执行或者eval()进行求值
s1 = input("请输入a+b:") #输入:8+9 print(eval(s1)) # 17 可以动态的执行代码. 代码必须有返回值 s2 = "for i in range(5): print(i)" a = exec(s2) # exec 执行代码不返回任何内容 # 0 # 1 # 2 # 3 # 4 print(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 # 2 code2 = "5+6+7" com2 = compile(code2, "", mode="eval") print(eval(com2)) # 18 code3 = "name = input('请输入你的名字:')" #输入:hello com3 = 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)) #-168324845050430382 lst = [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 os name = input("请输入你要导入的模块:") __import__(name) # 可以动态导入模块复制代码
帮 助
- help() : 函数用于查看函数或模块用途的详细说明
print(help(str)) #查看字符串的用途复制代码
调用相关
- callable() : 用于检查一个对象是否是可调用的. 如果返回True, object有可能调用失败, 但如果返回False. 那调用绝对不会成功
a = 10 print(callable(a)) #False 变量a不能被调用 # def f(): print("hello") print(callable(f)) # True 函数是可以被调用的复制代码
查看内置属性
- dir() : 查看对象的内置属性, 访问的是对象中的__dir__()方法
print(dir(tuple)) #查看元组的方法复制代码
很多初学者,对Python的概念都是模糊不清的,Python是什么,能做什么,学的时候,该按照什么线路去学习,学完往哪方面发展,想深入了解,想学习的同学欢迎收看课程。
相关免费学习推荐:python视频教程
以上是Python這68個內建函數,建議你吃透!的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

數組是一種資料結構,用於按順序儲存同質元素。儲存的元素由索引值或鍵來標識。 Python沒有特定的資料結構來表示陣列。但是,我們可以使用List資料結構或Numpy模組來處理陣列。在下面的文章中,我們將了解如何使用python內建函數反轉數組的元素。反轉數組元素的意思是把數組元素的順序從前向後改變。輸入輸出場景現在讓我們來看一些輸入輸出場景,以了解陣列元素的反轉。 Inputarray:[3,5,1,4,0,2]Outputarray:[2,0,4,1,5,3]輸入陣列元素的順序或排列被顛倒。使用內建

PHP提供了一系列內建函數用於執行各種任務,包括:字串操作(strcmp、strtoupper、strtolower)陣列處理(array_push、array_pop、in_array)數學運算(round、abs、max)檔案處理(fopen、fread 、fclose)

使用JavaScript內建函數進行字串操作在JavaScript中,有很多內建函數可以用來處理字串操作。這些函數可以幫助我們改變字串的大小寫、尋找子字串、替換字元等等。本文將介紹一些常用的字串操作函數,並給出對應的程式碼範例。 toUpperCase()和toLowerCase()這兩個函數分別用來將字串轉換為大寫和小寫。例如:varstr=

人生苦短,菜鳥學Python!我是菜鳥哥,今天,我們會一次分享6個堪稱神仙的內建函數。在許多計算機書籍中,它們也通常被介紹為高階函數。而我自己在日常工作中,經常使用它們來使程式碼更快,更易於理解。 Lambda 函數Lambda函數用於建立匿名函數,即沒有名稱的函數。它只是一個表達式,函數體比def簡單很多。當我們需要建立一個函數來執行單一操作並且可以在一行中編寫時,就可以用到匿名函數了。 lambda [arg1 [,arg2,.....argn]]:expression lambda的主

PHP作為一種流行的程式語言,其廣泛的使用得益於它的靈活性和強大的內建函數。這些內建函數既可以加速開發過程,還可以提高程式碼的可讀性和可維護性。無論是初學者還是經驗豐富的開發人員,都應該了解和掌握這些必不可少的工具。一些常用的PHP內建函數包括:字串函數在PHP中,字串是最常見的資料類型之一。字串函數可以讓我們對字串進行處理,例如查找、替換、分割、格式化

今天來給大家推薦一個Python當中超級好用的內建函數,那便是lambda方法,本篇教程大致和大家分享:什麼是lambda函數lambda函數過濾列表元素lambda函數和map()方法的聯用lambda函數和apply()方法的聯用什麼時候不適合使用lambda方法什麼是Lambda函數在Python當中,我們經常使用lambda關鍵字來聲明一個匿名函數,所謂地匿名函數,通俗地來講就是沒有名字的函數,具體的語法格式如下所示:lambda arguments : expression其中它可以接

Python作為一種靈活而強大的程式語言,已經在全球範圍內征服了程式設計師、資料專家和軟體工匠的心。 Python的大規模採用源自於其豐富的本機命令,這些命令可以簡化複雜的過程,縮短開發時間,並提高腳本的可讀性。在本文中,我們將深入探討十個關鍵的Python本地命令,每個程式設計師都需要掌握,以實現無縫和高效的編碼之旅。使用len()函數len()指令是一種簡單且不可或缺的機制,用於確定指定可迭代物件(如列表、元組或字串)的大小(即組件的計數)。範例expression="Python"

內建函數是Go核心的預定義函數,可輕鬆執行常見任務,例如型別轉換、字串處理和數學運算。具體來說,它們包括:類型轉換函數,允許在不同類型之間轉換,如string、int和float64。字串處理函數,支援取得長度、提取子字串、大小寫轉換等運算。數學運算函數,可計算絕對值、最大值和最小值,並進行四捨五入。這些函數簡化了開發過程,透過提供高效且標準化的方式執行各種操作,以提高程式碼品質和效率。
