Python内置函数功能汇总

Python内置函数
定义
内置函数(BIF,built-in functions)是Python内置对象类型之一,不需要额外导入任何模块即可直接使用,这些内置对象都封装在内置模块__builtins__之中,C语言实现并且进行了大量优化,具有非常快的运行速度,推荐优先使用。使用内置函数dir()可以查看所有内置函数和内置对象:>>> dir(builtins)
dir()函数不带参数时,返回当前范围内的变量、方法和定义的类型列表;带参数的属性、方法列表。如果参数包含方法——dir–(),该方法将被调用。如果参数不包含——dir–(),该方法将被最大限度地收集参数信息。
dir语法
dir([object]) object-----对象、变量、类型。

Python中的对象:标识、类型、值
Python采用的是基于值的内存管理方式,如果为不同变量赋值为相同值(仅适用于**-5至256**的整数和短字符串),这个值在内存中只有一份,多个变量指向同一块内存地址。
Python内置函数功能汇总_第1张图片
*使用help(函数名)可以查看某个函数的用法。

help(sum)
Help on built-in function sum in module builtins:

sum(iterable, start=0, /)
the sum of a ‘start’ value (default: 0) plus an iterable of numbers
When the iterable is empty, return the start value.
This function is intended specifically for use with numeric values and may
reject non-numeric types.
Python内置函数功能汇总_第2张图片
pow:返回两个数值的幂运算值或其与指定整数的模值

pow(2,3)
2**3

pow(2,3,5)
pow(2,3)%5
*十进制:1010,99
二进制:以0b或0B开头:0b010,-0B101
八进制:以0o或0O开头:0o121
十六进制:以0x或0X开头:0x9a,0x89
Python内置函数功能汇总_第3张图片
进制转换函数
bin(x) 将整数转换为二进制字符串

bin(4)
‘0b100’
oct(x) 将整数转化为八进制字符串

oct(11)
‘0o13’
hex(x) 将整数转换成十六进制字符串

hex(20)
‘0x14’
内置函数
abs()  获取绝对值

  1. abs()  获取绝对值

abs(-10)
10

abs(10)
10

abs(0)
0

a = -10
a.abs()
10

  1. all()  接受一个迭代器,如果迭代器的所有元素都为真,那么返回True,否则返回False

tmp_1 = [‘python’,123]
all(tmp_1)
True

tmp_2 = []
all(tmp_2)
True

tmp_3 = [0]
all(tmp_3)
False

  1. any()  接受一个迭代器,如果迭代器里有一个元素为真,那么返回True,否则返回False

  2. ascii()  调用对象的__repr__()方法,获得该方法的返回值.

  3. bin(), 6. oct(), 7. hex()   三个函数功能为:将十进制数分别转换为2/8/16进制。

  4. bool()  测试一个对象是True还是False.

  5. bytes()  将一个字符串转换成字节类型

s = ‘python’
x = bytes(s, encoding=‘utf-8’)
x
b’python’>>> a = ‘王’

s = bytes(a, encoding=‘utf-8’)
s
8 b’\xe7\x8e\x8b’

  1. str()  将字符类型/数值类型等转换为字符串类型

str(b’\xe7\x8e\x8b’, encoding=‘utf-8’) # 字节转换为字符串
‘王’

str(1) # 整数转换为字符串
‘1’

  1. challable()  判断对象是否可以被调用,能被调用的对象就是一个callables对象,比如函数和带有__call__()的实例

callable(max)
True

callable([1, 2, 3])
False

callable(None)
False

callable(‘str’)
False

  1. char(),13. ord()  查看十进制数对应的ASCII字符/查看某个ASCII对应的十进制数

chr(-1)
Traceback (most recent call last):
File “”, line 1, in
chr(-1)
ValueError: chr() arg not in range(0x110000)

chr(0)
‘\x00’

ord(’\x00’)
0

ord(‘7’)
55

classmethod()  用来指定一个方法为类的方法,由类直接调用执行,只有一个cls参数,执行雷的方法时,自动将调用该方法的类赋值给cls.没有此参数指定的类的方法为实例方法

class Province:
country = “中国”

 def __init__(self, name):
     self.name = name
    
  @classmethod
 def show(cls):  # 类方法,由类调用,最少要有一个参数cls,调用的时候这个参数不用传值,自动将类名赋值给cls
    print(cls)      

11 # 调用方法
12 Province.show()
15. complie()  将字符串编译成python能识别或可以执行的代码,也可以将文字读成字符串再编译

compile(source, filename, mode, flags=0, dont_inherit=False, optimize=-1)
将source编译为代码或者AST对象。代码对象能过通过exec语句来执行或者eval()进行求值。
参数source:字符串或者AST(abstract syntax trees)对象。
参数filename:代码文件名称,如果不是从文件读取代码则传递一些可辨认的值。
参数model:指定编译代码的种类。可以指定’exec’, ‘eval’, ‘single’。
参数flag和dont_inherit:这两个参数为可选参数。

s = “print(‘helloworld’)”
r = compile(s, “”, “exec”)
r

  1. complex()

创建一个值为real + imag * j的复数或者转化一个字符串或数为复数。如果第一个参数是字符串,则不需要指定第二个参数。
参数real:int,long,float或字符串。
参数imag:int,long,float。
17. delattr()  删除对象的属性

  1. dict()  创建数据字典

a = dict() 空字典
a
{}

b = dict(one = 1, two =2)
b
{‘one’: 1, ‘two’: 2}

c = dict({‘one’:1 ,‘two’:2})
c
{‘one’: 1, ‘two’: 2}

  1. dir()  不带参数时返回当前范围内的变量,方法和定义的类型列表,带参数时返回参数的属性,方法列表

dir()
[‘builtins’, ‘doc’, ‘loader’, ‘name’, ‘package’, ‘spec’, ‘li’, ‘li1’, ‘li2’, ‘li_1’]

dir(list)
[‘add’, ‘class’, ‘contains’, ‘delattr’, ‘delitem’, ‘dir’, ‘doc’, ‘eq’, ‘format’, ‘ge’, ‘getattribute’, ‘getitem’, ‘gt’, ‘hash’, ‘iadd’, ‘imul’, ‘init’, ‘iter’, ‘le’, ‘len’, ‘lt’, ‘mul’, ‘ne’, ‘new’, ‘reduce’, ‘reduce_ex’, ‘repr’, ‘reversed’, ‘rmul’, ‘setattr’, ‘setitem’, ‘sizeof’, ‘str’, ‘subclasshook’, ‘append’, ‘clear’, ‘copy’, ‘count’, ‘extend’, ‘index’, ‘insert’, ‘pop’, ‘remove’, ‘reverse’, ‘sort’]

  1. divmod()  分别取商和余数

1 >>> divmod(20,6)
2 (3, 2)
21. enumerate()  返回一个可以枚举的对象,该对象的next()方法将返回一个元组

test = [‘a’, ‘b’, ‘c’]
for k,v in enumerate(test):
print(k,v)

输出结果:

0 a
1 b
2 c

  1. eval()  将字符串str当成有效的表达式来求值并返回计算结果

s = “1+2*3”
type(s)

eval(s)
7

  1. exec()  执行字符串或complie方法编译过的字符串,没有返回值

  2. filter()  过滤器,构造一个序列,等价于[ item for item in iterables if function(item)],在函数中设定过滤条件,逐一循环迭代器中的元素,将返回值为True时的元素留下,形成一个filter类型数据

filter(function, iterable)
参数function:返回值为True或False的函数,可以为None。
参数iterable:序列或可迭代对象。

def bigerthan5(x):
… return x > 5

filter(bigerthan5, [3, 4, 5, 6, 7, 8])
[6, 7, 8]

  1. float()  讲一个字符串或整数转换为浮点数

float()
0.0

float(‘123’)
123.0

float(1)
61.0

float(‘a’)
Traceback (most recent call last):
File “”, line 1, in
float(‘a’)
ValueError: could not convert string to float: ‘a’

  1. format()  格式化输出字符串,format(value, format_spec)实质上是调用了value的__format__(format_spec)方法

1 >>> “I am {0}, I like {1}!”.format(“wang”, “moon”)
2 ‘I am wang, I like moon!’
27. frozenset()  创建一个不可修改的集合

1 frozenset([iterable])
2 set和frozenset最本质的区别是前者是可变的,后者是不可变的。当集合对象会被改变时(例如删除,添加元素),只能使用set,
3 一般来说使用fronzet的地方都可以使用set。
4 参数iterable:可迭代对象。
28. getattr()  获取对象的属性

1 getattr(object, name [, defalut])
2 获取对象object名为name的特性,如果object不包含名为name的特性,将会抛出AttributeError异常;如果不包含名为name的特性
3 且提供default参数,将返回default。
4 参数object:对象
5 参数name:对象的特性名
6 参数default:缺省返回值
7 >>> append = getattr(list, ‘append’)
8 >>> append
9
10 >>> mylist = [3, 4, 5]
11 >>> append(mylist, 6)
12 >>> mylist
13 [3, 4, 5, 6]
14 >>> method = getattr(list, ‘add’)
15 Traceback (most recent call last):
16 File “”, line 1, in
17 AttributeError: type object ‘list’ has no attribute ‘add’
18 >>> method = getattr(list, ‘add’, ‘NoMethod’)
19 >>> method
20 ‘NoMethod’

  1. globals()  返回一个描述当前全局变量的字典

1 >>> a = 1
2 >>> globals()
3 {‘loader’: , ‘a’: 1, ‘builtins’: , ‘doc’: None, ‘name’: ‘main’, ‘package’: None, ‘spec’: None}
30. hasattr()

1 hasattr(object,name)
2 判断对象object是否包含名为name的特性(hasattr是通过调用getattr(object,name))是否抛出异常来实现的。
3 参数object:对象
4 参数name:特性名称
5 >>> hasattr(list, ‘append’)
6 True
7 >>> hasattr(list, ‘add’)
8 False

  1. hash()  哈希值

1 hash(object)
2 如果对象object为哈希表类型,返回对象object的哈希值。哈希值为整数,在字典查找中,哈希值用于快递比价字典的键。
3 两个数值如果相等,则哈希值也相等。
32. help()  返回对象的帮助文档

  1. id()  返回对象的内存地址

1 >>> a = 1
2 >>> id(a)
3 1588522800
34. input()  获取用户输入内容

1 num = input(“请输入一个数字:”)
2 # 用户输入3
3 print(num)
4 # 输出结果
5 3
35. int()  将一个字符串或数值转换为一个普通整数

1 int([x[,radix]])
2 如果参数是字符串,那么它可能包含符号和小数点。参数radix表示转换的基数(默认是10进制)。
3 它可以是[2,36]范围内的值,或者0。如果是0,系统将根据字符串内容来解析。
4 如果提供了参数radix,但参数x并不是一个字符串,将抛出TypeError异常;
5 否则,参数x必须是数值(普通整数,长整数,浮点数)。通过舍去小数点来转换浮点数。
6 如果超出了普通整数的表示范围,一个长整数被返回。
7 如果没有提供参数,函数返回0。

  1. isinstance()  检查对象是否是类的对象,返回True或False

1 isinstance(obj, cls)
2 检查obj是否是类cls的对象, 返回True 或 False
3 class Foo(object):
4 pass
5 obj = Foo()
6 isinstance(obj, Foo)
37. issubclass()  检查一个类是否是另一个类的子类。返回True或False

1 issubclass(sub, super)
2 检查sub类是否是super类的派生类(子类)。返回True 或 False
3
4 class Foo(object):
5 pass
6
7 class Bar(Foo):
8 pass
9
10 issubclass(Bar, Foo)

  1. iter()

1 iter(o[, sentinel])
2 返回一个iterator对象。该函数对于第一个参数的解析依赖于第二个参数。
3 如果没有提供第二个参数,参数o必须是一个集合对象,支持遍历功能(iter()方法)或支持序列功能(getitem()方法),
4 参数为整数,从零开始。如果不支持这两种功能,将处罚TypeError异常。
5 如果提供了第二个参数,参数o必须是一个可调用对象。在这种情况下创建一个iterator对象,每次调用iterator的next()方法来无
6 参数的调用o,如果返回值等于参数sentinel,触发StopIteration异常,否则将返回该值。
39. len()  返回对象长度,参数可以是序列类型(字符串,元组或列表)或映射类型(如字典)

  1. list()  列表构造函数

1 list([iterable])
2 list的构造函数。参数iterable是可选的,它可以是序列,支持编译的容器对象,或iterator对象。
3 该函数创建一个元素值,顺序与参数iterable一致的列表。如果参数iterable是一个列表,将创建
4 列表的一个拷贝并返回,就像语句iterables[:]。 
41. locals()  打印当前可用的局部变量的字典

1 不要修改locals()返回的字典中的内容;改变可能不会影响解析器对局部变量的使用。
2 在函数体内调用locals(),返回的是自由变量。修改自由变量不会影响解析器对变量的使用。
3 不能在类区域内返回自由变量。
42. map()

1 map(function, iterable,…)
2 对于参数iterable中的每个元素都应用fuction函数,并将结果作为列表返回。
3 如果有多个iterable参数,那么fuction函数必须接收多个参数,这些iterable中相同索引处的元素将并行的作为function函数的参数。
4 如果一个iterable中元素的个数比其他少,那么将用None来扩展改iterable使元素个数一致。
5 如果有多个iterable且function为None,map()将返回由元组组成的列表,每个元组包含所有iterable中对应索引处值。
6 参数iterable必须是一个序列或任何可遍历对象,函数返回的往往是一个列表(list)。
7
8 li = [1,2,3]
9 data = map(lambda x :x*100,li)
10 print(type(data))
11 data = list(data)
12 print(data)
13
14 运行结果:
15
16
17 [100, 200, 300]

  1. max()  返回给定元素里最大值

1 max(iterable [,args…][, key])
2 如果只提供iterable参数,函数返回可遍历对象(如:字符串,元组或列表)中最大的非空元素。
3 如果提供多个参数,那么返回值最大的那个参数。
4 可选参数key是单参数的排序函数。
5 如果提供key参数,必须是以命名的形式,如:max(a, b, c, key = fun)
44. meoryview()

  1. min()  返回给定元素里最小值

1 min(iterable [,args…][, key])
2 如果只提供iterable参数,函数返回可遍历对象(如:字符串,元组或列表)中最小的非空元素。
3 如果提供多个参数,那么返回值最小的那个参数。
4 可选参数key是单参数的排序函数。
5 如果提供key参数,必须是以命名的形式,如:max(a, b, c, key = fun)
46. next()  返回一个可迭代数据结构(如列表)中的下一项

  1. object()

1 获取一个新的,无特性(geatureless)对象。Object是所有类的基类。它提供的方法将在所有的类型实例中共享。
2 该函数时2.2.版本新增,2.3版本之后,该函数不接受任何参数。
48. open()  打开文件

1 open(filename [, mode [, bufsize]])
2 打开一个文件,返回一个file对象。 如果文件无法打开,将处罚IOError异常。
3 应该使用open()来代替直接使用file类型的构造函数打开文件。
4 参数filename表示将要被打开的文件的路径字符串;
5 参数mode表示打开的模式,最常用的模式有:'r’表示读文本,‘w’表示写文本文件,‘a’表示在文件中追加。
6 Mode的默认值是’r’。
7 当操作的是二进制文件时,只要在模式值上添加’b’。这样提高了程序的可移植性。
8 可选参数bufsize定义了文件缓冲区的大小。0表示不缓冲;1表示行缓冲;任何其他正数表示使用该大小的缓冲区;
9 负数表示使用系统默认缓冲区大小,对于tty设备它往往是行缓冲,而对于其他文件往往完全缓冲。如果参数值被省却。
10 使用系统默认值。

  1. pow()  幂函数

1 r = pow(2, 10) # 2的10次方
2 print®
3
4 # 输出
5 1024
50. print()  输出函数

1 python2中的print语句被python3中的print()函数取代。
2 如何限制print的默认换行:
3 1. python2版本下,在print输出的最后加一个逗号’,’
4 2. python3.4以后,print(value, …,sep=’’,end=’\n’,file=sys.stdout,flush=False),将end设为空即可。
51. property()

  1. range()  根据需要生成一个指定范围的数字,可以提供你需要的控制来迭代指定的次数

1 用于创建包含连续算术值的列表(list)。常用于for循环。参数必须是普通整数。
2 参数step默认值为1,参数start的默认值为0。
3 全参数调用该函数将返回一个普通整数列表。
4 step 可以是正整数或者负整数。不可以为0,否则将处罚ValueError异常。
5 range(3)代表0,1,2.等价于range(0,3)
6 >>> range(0,10,2) #第一个参数是起始数,第二个是终止数(不包含这个),第三个数步数
7 >>>[0,2,4,6,8]

  1. repr()  将任意值转换为字符串,供计时器读取的形式

1 repr(object)
2 返回一个对象的字符串表示。有时可以使用这个函数来访问操作。
3 对于许多类型来说,repr()尝试返回一个字符串,eval()方法可以使用该字符串产生对象;
4 否则用尖括号括起来的,包含类名称和其他二外信息的字符串被返回。
54. reversed()   反转,逆序对象

1 reversed(seq)
2 返回一个逆序的iterator对象。参数seq必须是一个包含__reversed__()方法的对象或支持序列操作(len()和__getitem__())
3 该函数是2.4中新增的
55. round()  四舍五入

1 round(x [, n])
2 对参数x的第n+1位小数进行四舍五入,返回一个小数位数为n的浮点数。
3 参数n的默认值是0。结果是一个浮点数。如round(0.5)结果为1.0
4 >>> round(4,6)
5 4
6 >>> round(5,6)
7 5

  1. set()

  2. setattr()  与getattr()相对应

  3. slice()  切片功能

  4. sorted()  排序

1 >>> sorted([36,6,-12,9,-22]) 列表排序
2 [-22, -12, 6, 9, 36]
3 >>> sorted([36,6,-12,9,-22],key=abs) 高阶函数,以绝对值大小排序
4 [6, 9, -12, -22, 36]
5 >>> sorted([‘bob’, ‘about’, ‘Zoo’, ‘Credit’]) 字符串排序,按照ASCII的大小排序
6 [‘Credit’, ‘Zoo’, ‘about’, ‘bob’]
7 如果需要排序的是一个元组,则需要使用参数key,也就是关键字。
8 >>> a = [(‘b’,2), (‘a’,1), (‘c’,0)]
9 >>> list(sorted(a,key=lambda x:x[1])) 按照元组第二个元素排序
10 [(‘c’, 0), (‘a’, 1), (‘b’, 2)]
11 >>> list(sorted(a,key=lambda x:x[0])) 按照元组第一个元素排序
12 [(‘a’, 1), (‘b’, 2), (‘c’, 0)]
13 >>> sorted([‘bob’, ‘about’, ‘Zoo’, ‘Credit’],key=str.lower) 忽略大小写排序
14 [‘about’, ‘bob’, ‘Credit’, ‘Zoo’]
15 >>> sorted([‘bob’, ‘about’, ‘Zoo’, ‘Credit’],key=str.lower,reverse=True) 反向排序
16 [‘Zoo’, ‘Credit’, ‘bob’, ‘about’]

  1. staticmethod()

  2. str()  字符串构造函数

  3. sum()  求和

  4. super()  调用父类的方法

  5. tuple()  元组构造函数

  6. type()  显示对象所属的类型

  7. vars()

  8. zip()  将对象逐一配对

1 list_1 = [1,2,3]
2 list_2 = [‘a’,‘b’,‘c’]
3 s = zip(list_1,list_2)
4 print(list(s))
5
6 运行结果:
7
8 [(1, ‘a’), (2, ‘b’), (3, ‘c’)]

1 a = [(1,),(2,),(3,)]
2 r = zip(*a)
3 print(list®)
4 运行结果:
5 [(1, 2, 3)]
6 print(list®[0])
7 运行结果:
8 (1, 2, 3)

参考文献:http://www.cnblogs.com/xiao1/p/5856890.html

你可能感兴趣的:(学习笔记)