Python 内置函数

Python提供了68个内置函数,根据是否常用,分成三部分:

了解

all() any() bytes() callable() chr() complex() divmod() eval() exec() format() frozenset() globals() hash() help() id() input() int() iter() locals() next() oct() ord() pow() repr() round()

重点

abs() enumerate() filter() map() max() min() open() range() print() len() list() dict() str() float() reversed() set() sorted() sum() tuple() type() zip() dir()

后期

classmethod() delattr() getattr() hasattr() issubclass() isinstance() object() property() setattr() staticmethod() super()

了解部分

eval():剥去字符串的外衣,运算里面的代码。不建议使用

特别是网络传输的str,input输入的时候,sql注入等等绝对不能使用eval()。因为被转换的字符串容易被修改利用,而导致eval()直接运行里面的内容。

s1='1+2'
print(eval(s1))
>>>3

和eval()相似的另一个函数exec()用于代码流(多行代码),也不建议使用,高危。

hash():获取一个对象的哈希值,可哈希对象为不可变对象。

help():打印获取这个对象的使用方法。

callable():判断某个对象是否可调用。如果返回True,object仍然可能调用失败;但如果返回False,调用对象ojbect绝对不会成功。

bin():将十进制转换成二进制并返回。★★

oct():将十进制转化成八进制字符串并返回。★★

hex():将十进制转化成十六进制字符串并返回。★★

print(bin(10),type(bin(10)))  # 0b1010 <class 'str'>
print(oct(10),type(oct(10)))  # 0o12 <class 'str'>
print(hex(10),type(hex(10)))  # 0xa <class 'str'>

divmod():计算除数与被除数的结果,返回一个包含商和余数的元组(a // b, a % b)

round():保留浮点数的小数位数,默认保留整数。

pow():求xy次幂。(三个参数为xy的结果对z取余)

print(divmod(7,2))  	# (3, 1)
print(round(7/3,2))  	# 2.33
print(round(7/3))  		# 2
print(round(3.32567,3))  # 3.326
print(pow(2,3))  		# 两个参数为2**3次幂
print(pow(2,3,3))  		# 三个参数为2**3次幂,对3取余。

bytes():用于不同编码之间的转化。

s = '你好'						
bs = s.encode('utf-8')
print(bs)						# b'\xe4\xbd\xa0\xe5\xa5\xbd'
s1 = bs.decode('utf-8')
print(s1)						# 你好
bs = bytes(s,encoding='utf-8')
print(bs)						# b'\xe4\xbd\xa0\xe5\xa5\xbd'
b = '你好'.encode('gbk')
b1 = b.decode('gbk')
print(b1.encode('utf-8'))		# b'\xe4\xbd\xa0\xe5\xa5\xbd'

ord:输入字符找该字符编码的位置,可查Ascii码或Unicode

chr:输入位置数字找出其对应的字符

# ord 输入字符找该字符编码的位置
print(ord('a'))		# 97
print(ord('中'))		# 20013

# chr 输入位置数字找出其对应的字符
print(chr(97))		# a
print(chr(20013))	# 中

repr():返回一个对象的string形式(原形毕露)★★★ 面向对象经常用到

print(repr('{"name":"alex"}'))		# '{"name":"alex"}'
print('{"name":"alex"}')			# {"name":"alex"}

在格式化输出中,%r 也有repr()函数的功能:

s1 = '中国人'
msg = '我是%r' % s1
print(msg) 				# 我是'中国人'

all():可迭代对象中,全都是True才是True

any():可迭代对象中,有一个True 就是True

print(all([1,2,True,0]))		# False
print(any([1,'',0]))			# True

重点掌握

int():函数用于将一个字符串或数字转换为整型,可以用于取整。

float:函数用于将整数和字符串转换成浮点数。

complex:函数用于创建一个值为 real + imag * j 的复数或者转化一个字符串或数为复数。如果第一个参数为字符串,则不需要指定第二个参数。

print():屏幕输出函数

*格式:print(self, args, sep=' ', end='\n', file=None)

*args:位置参数,不限内容。

sep=' ':输出多个元素的间隔默认为一个空格。

print('a',3,5,11,'kv',sep='|')		# a|3|5|11|kv

end='\n':一次调用最后的结尾默认为一个换行符

list():将一个可迭代对象转换成列表

list1=list('amwkvi')
print(list1)			# ['a', 'm', 'w', 'k', 'v', 'i']

tuple():将一个可迭代对象转换成元组

dict():通过相应的方式创建字典

dict1 = dict([('one', 1), ('two', 2),('three', 3)])
dict2 = dict(one=1, two=2, three=3)
dict3 = dict({'one': 1, 'two': 2, 'three': 3})
dict4 = {'one': 1, 'two': 2, 'three': 3}
dict5 = dict.fromkeys('abc',[1,2,3])

abs():返回一个数值的绝对值。 ★★★

sum():求和,求可迭代对象(数值型)的和。 ★★★

l1 = [i for i in range(10)]
print(sum(l1))			# 45
print(sum(l1,100))		# 设置初始值100,就是在100的基础上进行做sum,结果为:145

reversed():将一个序列翻转, 返回翻转序列的迭代器

l1=list('amwkvi')
print(l1)				# ['a', 'm', 'w', 'k', 'v', 'i']
l2=list(reversed(l1))	# l2变量得到的是一个翻转的迭代器,所以需要用list函数进行转化
print(l2)				# ['i', 'v', 'k', 'w', 'm', 'a']

zip():拉链方法,将几个可迭代对象按照顺序组成一个生成器,生成器内容长短取决于这几个对象中最短的那个。 ★★★

l1 = [1, 2, 3, 4, 5]
tu1 = ('a', 'b', 'c')			# tu1最短,以该对象为准,一一对应产生一个生成器
s1 = 'kill'
obj = zip(l1, tu1, s1)
# for i in obj:
#     print(i)
print(list(obj))				# [(1, 'a', 'k'), (2, 'b', 'i'), (3, 'c', 'l')]
>>>(1, 'a', 'k')
(2, 'b', 'i')
(3, 'c', 'l')

min():求最小值。 ★★★★★

格式:min(*args, key=None)

例一:输出l1列表中绝对值最小值,后面的key将每个元素进行了取绝对值处理。

l1 = [1, 2, 3, 4, 5, -9, 19, -16]
print(min(l1,key=abs))				# 1

例二:求出值最小的键值对

dic = {'a': 3, 'b': 2, 'c': 1}
# print(min(dic))	 	# min默认会按照字典的键去比较大小,所以得出是a。
# def dic_value(k):		# 手动建立一个函数,输入键,返回值
#     return dic[k]
# print(min(dic,key=dic_value))	# 输出的是值最小的键

print(dic[min(dic,key=lambda k:dic[k])]) # 写成一行代码,使用匿名函数,传入键,返回值,min函数通过lambda对每个值进行比较大小。

例三:求列表中年龄最小那人的姓名

l2 = [('太白', 18), ('alex', 73), ('wusir', 35), ('口天吴', 41)]
print(min(l2, key=lambda k: k[1])[0])		# 太白
# k变量中每次传入的是列表中的每个元组,返回值为元组中的第二项,然后交给min函数进行比较。
# min的比较结果是一个元组,最后再取元组中的第一个元素,即人的名字。

max():求最大值。 ★★★★★

格式:max(*args, key=None)

凡是可以加key的函数:它会自动将可迭代对旬中的每个元素按照顺序传入key对应的函数中,以返回值进行比较大小。

sorted():排序函数,该函数对可迭代对象进行排序并返回一个新列表。默认从低到高进行排序,加上reverse=True参数可以进行逆序。

格式:sorted(*args, **kwargs)
l2 = [('太白', 18), ('alex', 73), ('wusir', 35), ('口天吴', 41)]
# 默认按照列表中每个元素的第一个内容进行排序。
print(sorted(l2))  # [('alex', 73), ('wusir', 35), ('口天吴', 41), ('太白', 18)]
# 加上key之后,使用匿名函数指定按照第二个内容进行排序。
print(sorted(l2, key=lambda x: x[1]))  
# [('太白', 18), ('wusir', 35), ('口天吴', 41), ('alex', 73)]
print(sorted(l2,key=lambda x:x[1],reverse=True))
# 加上reverse=True之后,将逆序排序。
# [('alex', 73), ('口天吴', 41), ('wusir', 35), ('太白', 18)]

filter():过滤、筛选,类似于列表推导式的筛选模式。该函数和列表推导器的区别是:返回值为一个迭代器。

举例:列表推导式和 filter() 演示

list1 = [2, 4, 11, 9, 5, 8]
# 列表推导式实现输出大于6的内容:[11, 9, 8]
print([i for i in list1 if i > 6])		# 返回的是个列表
# 使用filter()函数实现该功能:[11, 9, 8]
print(list(filter(lambda x: x > 6, list1)))	# 返回的是个迭代器,需要用list进行转换。

map()函数:类似于列表推导式的循环(遍历)模式。它和列表推导式的区别也是:返回值为一个迭代器。

举例:列表推导式和 map() 演示,需要程序生产出一个有规律的列表:[1, 4, 9, 16 ,25]

# 使用列表推导式生成列表:[1, 4, 9, 16 ,25]
print([i * i for i in range(1, 6)])
# 使用map函数进行生成列表:[1, 4, 9, 16 ,25]
obj = map(lambda i: i * i, range(1, 6))
# obj 为迭代器,想要得到列表需要用list方法实现
print(list(obj))

reduce()函数:该函数不属于内置函数,需要外部导入。

作用:

第一步:先把列表中的前俩个元素取出,按function规则计算出一个值'a',然后临时保存着;

第二步:将这个临时保存的值'a'和列表中第三个元素传入至function进行计算,再求出一个新的值'b';

第三步:又将这个新的值'b'覆盖掉'a',读取列表中第四个元素传入至function进行计算。以此类推。(个人理解类似 “i++”)

格式:reduce(function, sequence, initial=None)

在Python2.x版本中recude是直接 import就可以的,Python3.x版本中需要从functools这个包中导入。

举例:

from functools import reduce
list1 = [3, 5, 8, 2, 9, 7]

# 方法一:使用自定义函数实现将列表中所有元素进行相加
def func1(a, b):
    return a + b
print(reduce(func1, list1))		# 34

# 方法二:使用lambda实现将列表中所有数字变成一个整数
print(reduce(lambda a, b: a * 10 + b, list1))		# 358297