Python入门,一定要吃透这69个内置函数
itomcoil 2025-01-18 20:44 30 浏览
内置函数就是Python预先定义的函数,这些内置函数使用方便,无需导入,直接调用,大大提高使用者的工作效率,也更便于程序的阅读。截止到Python版本3.9.1,Python一共提供了69个内置函数。
如果你还没入门,或刚刚入门Python,那么,这篇文章非常适合你。为了方便记忆,木木老师会将这些内置函数分类介绍给大家。
- 数学运算(7个)
- 类型转换(24个)
- 序列操作(8个)
- 对象操作(9个)
- 反射操作(8个)
- 变量操作(2个)
- 交互操作(2个)
- 文件操作(1个)
- 编译执行(5个)
- 装饰器(3个)
数学运算(7个)
abs:求数值的绝对值
print(abs(-2)) # 绝对值:2
divmod:返回两个数值的商和余数
print(divmod(20,3)) # 求商和余数:(6,2)
max:返回可迭代对象中的元素中的最大值或者所有参数的最大值
print(max(7,3,15,9,4,13)) #求最大值:15
min:返回可迭代对象中的元素中的最小值或者所有参数的最小值
print(min(5,3,9,12,7,2)) #求最小值:2
pow:返回两个数值的幂运算值或其与指定整数的模值
print(pow(10,2,3)) # 如果给了第三个参数. 表示最后取余:1
round:对浮点数进行四舍五入求值
print(round(2.675, 2)) # 五舍六入:2.67
sum:对元素类型是数值的可迭代对象中的每个元素求和
print(sum([1,2,3,4,5,6,7,8,9,10])) # 求和:55
类型转换(24个)
bool:根据传入的参数的逻辑值创建一个新的布尔值
print(bool(0)) # 数值0、空序列等值为:False
int:根据传入的参数创建一个新的整数
print(int(3.6)) # 整数:3
float:根据传入的参数创建一个新的浮点数
print(float (3)) # 浮点数:3.0
complex:根据传入参数创建一个新的复数
print(complex (1,2)) # 复数:1+2j
str:将数据转化为字符串
print(str(123)+'456') #123456
bytearray:根据传入的参数创建一个新的字节数组
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')
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'
memoryview:根据传入的参数创建一个新的内存查看对象
v = memoryview(b'abcefg')
print(v[1]) # 98
ord:返回Unicode字符对应的整数
print(ord('中')) # '中'字在编码表中的位置:20013
chr:返回整数所对应的Unicode字符
print(chr(65)) # 已知码位求字符:A
bin:将整数转换成2进制字符串
print(bin(10)) # 二进制:0b1010
oct:将整数转化成8进制数字符串
print(oct(10)) # 八进制:0o12
hex:将整数转换成16进制字符串
print(hex(10)) # 十六进制:0xa
tuple:根据传入的参数创建一个新的元组
print(tuple([1,2,3,4,5,6])) # (1, 2, 3, 4, 5, 6)
list:根据传入的参数创建一个新的列表
print(list((1,2,3,4,5,6))) # [1, 2, 3, 4, 5, 6]
dict:根据传入的参数创建一个新的字典
print(dict(a = 1,b = 2)) # 创建字典: {'b': 2, 'a': 1}
range:根据传入的参数创建一个新的range对象
for i in range(15,-1,-5):
print(i)
# 15
# 10
# 5
# 0
set:根据传入的参数创建一个新的集合
a = set(range(10))
print(a) # 创建集合:{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
frozenset:根据传入的参数创建一个新的不可变集合
a = frozenset(range(10))
print(a) #frozenset({0, 1, 2, 3, 4, 5, 6, 7, 8, 9})
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
iter:根据传入的参数创建一个新的可迭代对象
lst = [1, 2, 3]
for i in iter(lst):
print(i)
# 1
# 2
# 3
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]
super:根据传入的参数创建一个新的子类和父类关系的代理对象
class A:
def add(self, x):
y = x+1
print(y)
class B(A):
def add(self, x):
super().add(x)
b = B()
b.add(2) # 3
object:创建一个新的object对象
class A:
pass
print(issubclass(A,object)) #默认继承object类 # True
print(dir(object))
# ['__class__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__']
序列操作(8个)
all:判断可迭代对象的每个元素是否都为True值
print(all([1,'hello',True,9])) #True
any:判断可迭代对象的元素是否有为True值的元素
print(any([0,0,0,False,1,'good'])) #True
filter:使用指定方法过滤可迭代对象的元素
def is_odd(n):
return n % 2 == 1
newlist = filter(is_odd, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
print(newlist) # [1, 3, 5, 7, 9]
map:使用指定方法去作用传入的每个可迭代对象的元素,生成新的可迭代对象
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]
next:返回可迭代对象中的下一个元素值
it = iter([1, 2, 3, 4, 5])
while True:
try:
x = next(it)
print(x)
except StopIteration:
break
# 1
# 2
# 3
# 4
# 5
reversed:反转序列生成新的可迭代对象
print(list(reversed([1,2,3,4,5]))) # [5, 4, 3, 2, 1]
sorted:对可迭代对象进行排序,返回一个新的列表
a = [5,3,4,2,1]
print(sorted(a,reverse=True)) # [5, 4, 3, 2, 1]
zip:聚合传入的每个迭代器中相同位置的元素,返回一个新的元组类型迭代器
my_list = [11,12,13]
my_tuple = (21,22,23)
print(list(zip(my_list,my_tuple))) # [(11, 21), (12, 22), (13, 23)]
对象操作(9个)
help:返回对象的帮助信息
print(help(str)) #查看字符串的用途
dir:返回对象或者当前作用域内的属性列表
print(dir(tuple)) #查看元组的方法
id:返回对象的唯一标识符
s = 'alex'
print(id(s)) # 139783780730608
hash:获取对象的哈希值
s = 'alex'
print(hash(s)) #-168324845050430382
lst = [1, 2, 3, 4, 5]
print(hash(lst)) #报错,列表是不可哈希的
type:返回对象的类型,或者根据传入的参数创建一个新的类型
dict = {'Name': 'Zara', 'Age': 7}
print("Variable Type : %s" % type (dict)) # Variable Type : <type 'dict'>
len:返回对象的长度
mylist = ["apple", "orange", "cherry"]
x = len(mylist)
print(x) # 3
ascii:返回对象的可打印表字符串表现方式
s = 5
print(ascii(s)) # 5
format:格式化显示值
s = "hello world!"
print(format(s, "^20")) #居中
print(format(s, "<20")) #左对齐
print(format(s, ">20")) #右对齐
# hello world!
# hello world!
# hello world!
vars:返回当前作用域内的局部变量和其值组成的字典,或者返回对象的属性列表
class Person:
name = "John"
age = 36
country = "norway"
x = vars(Person)
print(x)
# {'__module__': '__main__', 'name': 'Bill', 'age': 63, 'country': 'USA', '__dict__': <attribute '__dict__' of 'Person' objects>, '__weakref__': <attribute '__weakref__' of 'Person' objects>, '__doc__': None}
反射操作(8个)
__import__:动态导入模块
import os
name = input("请输入你要导入的模块:")
__import__(name) # 可以动态导入模块
isinstance:判断对象是否是类或者类型元组中任意类元素的实例
arg=123
print(isinstance(arg, int)) # 输出True
issubclass:判断类是否是另外一个类或者类型元组中任意类元素的子类
class A:
pass
class B(A):
pass
print(issubclass(B,A)) # 返回 True
hasattr:检查对象是否含有属性
class Coordinate:
x = 10
y = -5
z = 0
point1 = Coordinate()
print(hasattr(point1, 'x'))
print(hasattr(point1, 'y'))
print(hasattr(point1, 'z'))
print(hasattr(point1, 'no')) # 没有该属性
# True
# True
# True
# False
getattr:获取对象的属性值
class Person():
age = 14
Tom = Person()
print(getattr(Tom,'age')) # 14
setattr:设置对象的属性值
class A():
name = "吊车尾"
a = A()
setattr(a, "age", 24)
print(a.age) # 24
delattr:删除对象的属性
class Person:
def __init__(self, name, age):
self.name = name
self.age = age
tom = Person("Tom", 35)
print(dir(tom)) # ['__doc__', '__init__', '__module__', 'age', 'name']
delattr(tom, "age")
print(dir(tom)) # ['__doc__', '__init__', '__module__', 'name']s
callable:检测对象是否可被调用
a = 10
print(callable(a)) #False 变量a不能被调用
变量操作(2个)
globals:返回当前作用域内的全局变量和其值组成的字典
x = 'hello'
a = 8888888
print(globals()) #返回一个全局变量的字典,包括所有导入的变量x,a
# {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x000000000212C2B0>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'D:/Pythonproject/111/global.py', '__cached__': None, 'x': 'hello', 'a': 8888888}
locals:返回当前作用域内的局部变量和其值组成的字典
print(locals())
# {'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x10ab79358>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': '/Users/pankaj/Documents/github/journaldev/Python-3/basic_examples/python_locals_example.py', '__cached__': None}
交互操作(2个)
print:向标准输出对象打印输出
print(1,2,3) # 1 2 3
input:读取用户输入值
a = input('请输入你的姓名') #输入:张三
print(a) # 张三
文件操作(1个)
open:使用指定的模式和编码打开文件,返回文件读写对象
f = open('file',mode='r',encoding='utf-8')
f.read()
f.close()
编译执行(5个)
compile:将字符串编译为代码或者AST对象,使之能够通过exec语句来执行或者eval进行求值
code = "for i in range(3): print(i)"
com = compile(code, "", mode="exec")
exec(com)
# 0
# 1
# 2
eval:执行动态表达式求值
code = "5+6+7"
com = compile(code, "", mode="eval")
print(eval(com)) # 18
exec:执行动态语句块
s = "for i in range(5): print(i)"
a = exec(s)
# 0
# 1
# 2
# 3
# 4
repr:返回一个对象的字符串表现形式(给解释器)
class test:
def __init__(self,name,age):
self.age = age
self.name = name
def __repr__(self):
return "Class_Test[name="+self.name+",age="+str(self.age)+"]"
t = test("Zhou",30)
print(t) # Class_Test[name=Zhou,age=30]
breakpoint:暂停脚本的执行,允许在程序的内部手动浏览
装饰器(3个)
property:标示属性的装饰器
class C:
def __init__(self):
self._name = ''
@property
def name(self):
"""i'm the 'name' property."""
return self._name
@name.setter
def name(self,value):
if value is None:
raise RuntimeError('name can not be None')
else:
self._name = value
classmethod:标示方法为类方法的装饰器
class C:
@classmethod
def f(cls,arg1):
print(cls)
print(arg1)
staticmethod:标示方法为静态方法的装饰器
class Student(object):
def __init__(self,name):
self.name = name
@staticmethod
def sayHello(lang):
print(lang)
if lang == 'en':
print('Welcome!')
else:
print('你好!')
收集不易,记得给木木一个小反馈哦~
PS:由于空格原因,这些代码直接复制运行不了哦~想学习的同学,可以私信回复【资料】获取原文档学习。
相关推荐
- python创建文件夹,轻松搞定,喝咖啡去了
-
最近经常在录视频课程,一个课程下面往往有许多小课,需要分多个文件夹来放视频、PPT和案例,这下可好了,一个一个手工创建,手酸了都做不完。别急,来段PYTHON代码,轻松搞定,喝咖啡去了!import...
- 如何编写第一个Python程序_pycharm写第一个python程序
-
一、第一个python程序[掌握]python:python解释器,将python代码解释成计算机认识的语言pycharm:IDE(集成开发环境),写代码的一个软件,集成了写代码,...
- Python文件怎么打包为exe程序?_python3.8打包成exe文件
-
PyInstaller是一个Python应用程序打包工具,它可以将Python程序打包为单个独立可执行文件。要使用PyInstaller打包Python程序,需要在命令行中使用py...
- 官方的Python环境_python环境版本
-
Python是一种解释型编程开发语言,根据Python语法编写出来的程序,需要经过Python解释器来进行执行。打开Python官网(https://www.python.org),找到下载页面,选择...
- [编程基础] Python配置文件读取库ConfigParser总结
-
PythonConfigParser教程显示了如何使用ConfigParser在Python中使用配置文件。文章目录1介绍1.1PythonConfigParser读取文件1.2Python...
- Python打包exe软件,用这个库真的很容易
-
初学Python的人会觉得开发一个exe软件非常复杂,其实不然,从.py到.exe文件的过程很简单。你甚至可以在一天之内用Python开发一个能正常运行的exe软件,因为Python有专门exe打包库...
- 2025 PyInstaller 打包说明(中文指南),python 打包成exe 都在这里
-
点赞标记,明天就能用上这几个技巧!linux运维、shell、python、网络爬虫、数据采集等定定做,请私信。。。PyInstaller打包说明(中文指南)下面按准备→基本使用→常用...
- Python自动化办公应用学习笔记40—文件路径2
-
4.特殊路径操作用户主目录·获取当前用户的主目录路径非常常用:frompathlibimportPathhome_dir=Path.home()#返回当前用户主目录的Path对象...
- Python内置tempfile模块: 生成临时文件和目录详解
-
1.引言在Python开发中,临时文件和目录的创建和管理是一个常见的需求。Python提供了内置模块tempfile,用于生成临时文件和目录。本文将详细介绍tempfile模块的使用方法、原理及相关...
- python代码实现读取文件并生成韦恩图
-
00、背景今天战略解码,有同学用韦恩图展示各个产品线的占比,效果不错。韦恩图(Venndiagram),是在集合论数学分支中,在不太严格的意义下用以表示集合的一种图解。它们用于展示在不同的事物群组之...
- Python技术解放双手,一键搞定海量文件重命名,一周工作量秒搞定
-
摘要:想象一下,周五傍晚,办公室的同事们纷纷准备享受周末,而你,面对着堆积如山的文件,需要将它们的文件名从美国日期格式改为欧洲日期格式,这似乎注定了你将与加班为伍。但别担心,Python自动化办公来...
- Python路径操作的一些基础方法_python路径文件
-
带你走进@机器人时代Discover点击上面蓝色文字,关注我们Python自动化操作文件避开不了路径操作方法,今天我们来学习一下路径操作的一些基础。Pathlib库模块提供的路径操作包括路径的...
- Python爬取下载m3u8加密视频,原来这么简单
-
1.前言爬取视频的时候发现,现在的视频都是经过加密(m3u8),不再是mp4或者avi链接直接在网页显示,都是经过加密形成ts文件分段进行播放。今天就教大家如果通过python爬取下载m3u8加密视频...
- 探秘 shutil:Python 高级文件操作的得力助手
-
在Python的标准库中,shutil模块犹如一位技艺精湛的工匠,为我们处理文件和目录提供了一系列高级操作功能。无论是文件的复制、移动、删除,还是归档与解压缩,shutil都能以简洁高效的方式完成...
- 怎么把 Python + Flet 开发的程序,打包为 exe ?这个方法很简单!
-
前面用Python+Flet开发的“我的计算器v3”,怎么打包为exe文件呢?这样才能分发给他人,直接“双击”运行使用啊!今天我给大家分享一个简单的、可用的,把Flet开发的程序打包为...
- 一周热门
- 最近发表
-
- python创建文件夹,轻松搞定,喝咖啡去了
- 如何编写第一个Python程序_pycharm写第一个python程序
- Python文件怎么打包为exe程序?_python3.8打包成exe文件
- 官方的Python环境_python环境版本
- [编程基础] Python配置文件读取库ConfigParser总结
- Python打包exe软件,用这个库真的很容易
- 2025 PyInstaller 打包说明(中文指南),python 打包成exe 都在这里
- Python自动化办公应用学习笔记40—文件路径2
- Python内置tempfile模块: 生成临时文件和目录详解
- python代码实现读取文件并生成韦恩图
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)