python基础之常用内置函数
前言
python有许多内置的函数,它们定义在python的builtins模块,在python的代码中可以直接使用它们。
常用的内置函数
类型转换
- int
python的整数类型都是int类型的实例,但int类也可以被调用,将参数转换成int类型。
class Dog(object):
def __int__(self):
return 100
if __name__ == "__main__":
dog = Dog()
print(int(dog)) # 100
# int方法调用了参数的__int__魔法方法。
str:调用参数的__str__方法获取返回值;
float:调用参数的__float__方法获取返回值;
complex:调用参数的__complex__方法获取返回值;
class Dog(object):
def __float__(self):
return 3.6
def __complex__(self):
return (3-4j)
def __str__(self):
return 'str'
if __name__ == "__main__":
dog = Dog()
print(str(dog)) # str
print(float(dog)) # 3.6
print(complex(dog)) # (3-4j)
dict:将一个对象转化成字典;
list:将一个对象转化成列表;
tuple:将一个对象转化成元组;
slice:创建一个切片对象,list和tuple类型可用;
my = [i for i in range(10)]
print(my[slice(0,3,2)]) # 无论索引、切片操作都调用了可迭代对象的__getitem__方法。
算术计算
abs():求参数的绝对值,只支持一个参数,会调用参数的__abs__魔法方法;只支持int和float类型
bin(*args, **kwargs):返回整数的二进制表示形式,只支持一个参数,调用参数的__bin__方法,只支持int类型
divmod(x, y):求x//y和x%y的值,即商和余数的元组,调用__divmod__方法,只支持int和float类型
hash():获取一个对象的散列值,相等的两个数哈希值相等,反过来不一定成立
hex(*args, **kwargs):求整数的十六进制表示形式,调用__hex__方法,只支持Int类型
oct(*args, **kwargs):求整数的八进制表示形式,调用__oct__方法,只支持Int类型
pow(*args, **kwargs):求幂,如pow(3,4)表示3的4字方,pow(3,4,5)表示3**4%5,调用__pow__方法,只支持int和float类型
sum(*args, **kwargs):求和,只支持由int类型和float类型构成的可迭代对象,调用__sum__方法,支持所有的可迭代类型
- round():对于一个数四舍五入计算,第二参数可以指定精度
print(round(3.5)) # 4
print(round(4.77,1)) # 4.8
迭代运算
- all:对可迭代对象的每个元素进行布尔判断,所有为真返回真,存在假则返回假
print(all((1,'df',[1,2],1.2))) # 结果:True
print(all((None,{1,2}))) # 结果:False
- any:对可迭代对象的每个元素进行布尔判断,所有为假返回假,存在真则返回真
print(any((1,'df',[1,2],''))) # 结果:True
print(any((None,[]))) # 结果:False
- max和min:计算容器或多个值的最大值与最小值,可以通过key参数指定比较的规则,默认是算术大小比较。
print(max([1,2,3,4,5])) # 5
print(max('name','jj','age',key=lambda x:len(x))) # 'name'
- sorted:对任何的可迭代对象进行排序,通过key指定排序规则, reverse指定方向;返回的结果是一个新的对象
print(sorted(['name','age','hight'], key=lambda x:len(x), reverse=False))
print(sorted([4,3,6,8]))
编码运算
- ascii:返回一个对象的ascii编码,windows系统对象默认的编码是ascii,支持大部分类型
print(ascii('我')) # '\u6211'
print(ascii('x')) # 'x'
print(ascii('100')) # '100'
print(ascii(100)) # 100
print(ascii(10000000000000000)) # 10000000000000000
- chr:返回一个整数序号在ascii表中代表的单字符,只支持整数
print(chr(97)) # a
print(chr(4)) # ? 不识别,没有对应的字符
ord:返回一个单字符代表的Unicode编码。
compile:将字符串编译为字节代码,方便exec或eval去执行。
语法:compile(source, filename, mode[, flags[, dont_inherit]])
# 参数:
source -- 字符串
filename -- 代码文件名称,如果不是从文件读取代码则传递一些可辨认的值。
mode -- 指定编译代码的种类。可以指定为 exec, eval, single。
flags -- 变量作用域,局部命名空间,如果被提供,可以是任何映射对象。
x = compile('print("hello world")', '', 'exec')
exec(x) # hello world
- eval:用来执行一个字符串表达式,并返回表达式的值。
参数:
expression:表达式字符串
globals:变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。
locals:变量作用域,局部命名空间,如果被提供,可以是任何映射对象。
for example:
x = 3
def test():
x = 1
res = eval("x ** 3", globals(), locals())
print(res)
return res
if __name__ == "__main__":
test() # 如果参数只有globals(),值为27,如果提供了locals(),命名空间为本函数,值为1
- exec:执行储存在字符串或文件中的 Python 语句,相比于 eval,exec可以执行更复杂的 Python 代码,返回的永远是None。
# 参数:
expression:表达式字符串
globals:变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。
locals:变量作用域,局部命名空间,如果被提供,可以是任何映射对象。
for example:
exec("def foo(): print('hello world')")
exec("foo()")
进程结束
- exit()和quit():用来退出进程,抛出SystemExit异常,解释器会捕获该异常退出程序。
try:
exit(0)
except SystemExit as e:
print(e) # 0
print('jjjj')
# SystemExit会搜集到错误的code,0表示正常退出,1表示异常退出
输入输出
input:该方法会打开一个交互式的窗口,阻塞等待用户的输入;
print():这个算是python最常用的方法之一了,在命令窗打印内容,会调用参数的__str__方法,如果该方法不存在则调用__repr__方法,并将返回的值交给file参数。
参数:
values:需要输出的值
sep:设置间隔符,默认为空
end:添加的结束符
file:一个文件对象
for example:
print('name','xx',file=open('./test.txt','w'))
命名空间
globals():获取所在模块的全局命名空间,即所有的方法、类、变量等名字和对象键值对构成的字典,包括导入的对象;
locals():获取局部的命名空间,即本类或本函数的的属性、方法等构成的字典;
vars(p_object):无参数返回locals(),有参数返回参数的__dict___
判断
callable:判断参数是否支持调用,返回布尔值,本质是判断参数对象存在__call__方法,只支持一个参数
delattr(x, y):将x对象的y属性删除,如果没有这个属性会报错,所以一般先要判断一下,调用了x的__delattr__方法
class A(object):
age = 20
def __init__(self):
self.name = 'cai'
if __name__ == "__main__":
a = A()
delattr(a, 'name') # 实例只能删除实例属性
delattr(A,'age') # 类只能删除类属性
- hasattr(x,y):判断x对象是否存在y属性
class A(object):
age = 20
def __init__(self):
self.name = 'cai'
if __name__ == "__main__":
a = A()
print(hasattr(A,'age')) # True
print(hasattr(A,'name')) # false
print(hasattr(a,'age')) # True,实例拥有类的属性
print(hasattr(a,'name')) # True
- getattr(x,y):获取x对象的y属性,如果没有报错,所以需要判断,实例可以获取类的属性,调用了x对象的__getattribute__方法。
class A(object):
age = 20
def __init__(self):
self.name = 'cai'
if __name__ == "__main__":
a = A()
print(getattr(A,'age')) # 20
print(getattr(a,'age')) # 20
print(getattr(a,'name')) # 'cai'
print(getattr(a,"hight")) # 报错
- setattr(x, y, v):设置x对象的y属性的值是v,如果存在则修改,不存在则创建,调用x对象的__setattr__方法
class A(object):
age = 20
def __init__(self):
self.name = 'cai'
if __name__ == "__main__":
a = A()
print(getattr(A,'age')) # 20
setattr(A,'age',30) # 修改类属性
print(getattr(A, 'age')) # 30
print(getattr(a, 'age')) # 30,如果实例没有盖属性会去寻找类有没有这个属性
setattr(a, 'age', 40) # 设置实例属性
print(getattr(A, 'age')) # 30
print(getattr(a, 'age')) # 40
- isinstance和issubclass:判断一个对象的类型和一个对象是否是另一个对象子类
class A(object):
age = 20
def __init__(self):
self.name = 'cai'
class B(object):
pass
if __name__ == "__main__":
a = A()
print(isinstance(a,A)) # True
print(isinstance(a,(A,B))) # True 只要有一个符合就返回True
# 同理issubclass的使用和isinstance一样
其他
repr():函数将对象转化为供解释器读取的形式。
iter():获取一个可迭代对象的迭代器,调用参数的__iter__方法;
next():获取一个迭代器的元素值,调用可迭代对象的__next__方法。
len():计算一个容器中的项数,会调用参数的__len__方法
dir:
函数不带参数时,返回当前范围内的变量、方法和定义的类型列表;带参数时,返回参数的属性、方法列表。如果参数包含方法_dir_(),该方法将被调用。如果参数不包含|_dir_(),该方法将最大限度地收集参数信息。
class A(object):
age = 20
def __init__(self):
self.name = 'cai'
if __name__ == "__main__":
a = A()
print(dir(a)) # 对实例对象返回[]
print(dir(A)) # 参数需要是对象、变量、类型。
dir()和__dict__返回的数据的区别在于__dir__获取对象的所有属性、方法的名字组成列表,包括继承父类的;__dict__记录当前类定义的所有的属性、方法的名字与具体对象组成的键值对。
- id:获取一个对象在内存空间中的地址;
总结
可以看到很多内置函数的源码都是pass,这是因为源码展示给我们的只有名字而已,方便我们调用,它们的具体实现算法被隐藏;
有些方法的算法直接内置在解释器中,可以直接调用;有些会去调用方法的参数相对应的魔法方法,大部分魔法方法的实现算法也内置在了解释器中;
内置函数都是作为全局函数来使用的,不需要导入即可直接使用,也就是说解释器启动是就加载了内置函数的上下文;
参考
python基础之常用内置函数的更多相关文章
- Python 基础之常用内置函数
1.常用内置函数 (1)abs 绝对值函数 intvar = -9 res = abs(intvar)print(res) (2)round 四舍五入 (n.5 n为偶数则舍去 n.5 n为奇数 ,则 ...
- PYTHON语言之常用内置函数
一 写在开头本文列举了一些常用的python内置函数.完整详细的python内置函数列表请参见python文档的Built-in Functions章节. 二 python常用内置函数请注意,有关内置 ...
- Python基础学习五 内置函数
1.函数补充: 1)函数返回值return可以有多个 2)补充示例: nums = [0,1,2,3,4,5,6,7,8] #如何将list里面的元素变为字符串类型 new_nums = [str(x ...
- python 基础篇 15 内置函数和匿名函数
------------------------>>>>>>>>>>>>>>>内置函数<<< ...
- python基础学习笔记——内置函数
一. 简介 python内置了一系列的常用函数,以便于我们使用,python英文官方文档详细说明:点击查看, 为了方便查看,将内置函数的总结记录下来. 二. 使用说明 以下是Python3版本所有的内 ...
- python基础 (装饰器,内置函数)
https://docs.python.org/zh-cn/3.7/library/functions.html 1.闭包回顾 在学习装饰器之前,可以先复习一下什么是闭包? 在嵌套函数内部的函数可以使 ...
- python基础学习Day14 内置函数 匿名函数
一.内置函数里几个高频重要函数 (1)min\max函数的用法 以min函数的为例: min:返回可迭代对象的最小值(可加key,key为函数名,通过函数的规则,返回最小值). l1 =[(,),(, ...
- python基础一 day15 内置函数
'\r' 回车,回到当前行的行首,而不会换到下一行,如果接着输出的话,本行以前的内容会被逐一覆盖: '\n' 换行,换到当前位置的下一行,而不会回到行首: # print()# input()# le ...
- Python学习笔记-常用内置函数
输出:print() 功能:输出打印 语法:print(*objects, sep=' ', end='\n', file=sys.stdout) 参数:objects----复数,表示可以一次输出多 ...
随机推荐
- Delphi通过ADO链接数据库及对数据库的增加,删除,修改,读取操作实例教程4
ADO是一种程序对象,用于表示用户数据库中的数据结构和所包含的数据.ADO(ActiveXDataObjects,ActiveX数据对象)是Microsoft提出的应用程序接口(API)用以实现访问关 ...
- Delphi实现ERP单据列表栏目设置
什么都不用说了,ERP你懂的.一张报表,不同的客户都可以调死你.直接上图 通过这个设置界面,直接生成参数调整报表所用的DBGridEh.对,是DBGridEh,不是DBGrid,也不是CXGrid. ...
- postman md5加密 然后传给下一个接口作为参数调用
https://www.v2ex.com/api/nodes/show.json?name=python get请求 断言: tests["Body matches string" ...
- Socket 传一幅图片给另一个终端
练习Socket传文件,先添加一个组件,简化socket发送和接收文件, 获取IP和端口的类 public static class AddressHelper { /// <summary&g ...
- 【JavaScript】checkBox的多选行<tr>信息获取
页面的列表table显示(后台model.addAttribute("page", page);传来page信息,page通过foreach标签迭代展示表格数据): <!-- ...
- [您有新的未分配科技点]数位dp:从懵X到板子(例题:HDU2089 不要62)
数位dp主要用来处理一系列需要数数的问题,一般套路为“求[l,r]区间内满足要求的数/数位的个数” 要求五花八门……比如“不出现某个数字序列”,“某种数的出现次数”等等…… 面对这种数数题,暴力的想法 ...
- 信息收集利器——Nmap
环境:kali2.0 常用的Nmap命令总结: 1.扫描单个IP地址 nmap 192.168.56.1 2.扫描一个网络中IP地址范围 nmap 192.168.56.1-255 3.扫描目标主机的 ...
- 洛谷 P2258 子矩阵
题目描述 给出如下定义: 子矩阵:从一个矩阵当中选取某些行和某些列交叉位置所组成的新矩阵(保持行与列的相对顺序)被称为原矩阵的一个子矩阵. 例如,下面左图中选取第2.4行和第2.4.5列交叉位置的元素 ...
- BZOJ 3709&&AGC 018 C——多段排序的微扰法
BZOJ 3709• 有n只怪物,你的初始生命值为z.• 为了打败第i只怪物,你需要消耗cost[i]点生命值,但怪物死后会使你恢复val[i]点生命值.• 任何时候你的生命值都不能小于等于0.• 问 ...
- 【learning】加权拟阵与贪心
首先.. 这篇东西的话算是一个关于拟阵部分知识的小总结,有些语言相对来说偏向便于理解方面,所以可能..有一些说法会不是那么严谨大概是这样 一些概念 线性无关:一组数据中没有一个量可以写成其余量的线 ...