前言时刻
这两天写文章写得快吐了,写完信息安全的读书笔记然后又写一个软件使用教程,难受了。不过坚持住就好,继续奋斗吧。
来来总结一波:
今天学习了lambda匿名函数、一些重要的内置函数如:abs、sum、max、min、zip、sorted、filter、map
一般性重要的是:bytes、int、chr、ord、bin、oct、hex、repr、all、any等
1、lambada函数
lambda 函数又称为匿名函数,从语法上看它就是一个函数,而且功能还很简单。
# 语法: func = lambada 形参:结果 func1 = lambda a, b: a+b func1(1, 2) # 3
但是 Python 为什么还要单独搞一个匿名函数呢?答案是自有其道理的。一般 lambda 是与其他匿名函数组合使用,起到超重要的作用。
例如:和 sorted 函数配合使用,使用 lambda 可以将其成员中的一部分作为排序依据。
dic = {"name": "13", 'hobby': '6666', 'age': '14'} # 1.默认排序 print(sorted(dic)) # ['age', 'hobby', 'name'] # 2.使用值作为排序依据,从小到大 sorted(dic, key=lambda a:int(dic[a]),reverse=False) # ['name', 'age', 'hobby']
2、内置函数
内置函数是Python中最重要的亮点之一,有些函数真的可以让你一行低十行。
2.1 重要函数
- sum(iterable):求一个迭代对象的所有元素的和
- max(iterable, key=lambda x:x)/min():求迭代对象中的元素的最大值或最小值
# 今天写的内置函数都是非常重要的 lis = [1, 2, 3, 4, 5] dic = {"name": "13", 'hobby': '6666', 'age': '14'} # 1. sum print(sum(lis)) # 15 print(sum((1, 2, 3, 4, 5))) # 15 # 2. max min def max_test(x): return int(dic[x]) max(lis) # 5 max(dic, key=lambda x:int(dic[x])) # hobby max(dic, key=max_test) # hobby # 可以看出,key也同样可以用一个函数替代lambda,也说明lambda就是简单的函数
- zip([iterable,...]):又称拉链函数,将几个可迭代对象中的数据打包成一个元组,这个功能太实用了。
- sorted(iteable, key=, reverse=True/False): 对里面的迭代对象进行排序,生成一个新的 list 列表对象,可以添加 key 控制排序依据。reverse=True则为从大到小,默认是False从小到大。
# 3. zip函数 lis1 = [1, 2, 3] lis2 = (4, 5, 6) lis3 = (7, 8, 9) zip(lis1, lis2, lis3) # 4.sorted函数 dic = {"name": "13", 'hobby': '6666', 'age': '14'} lis = [23, 4, 5, 1, 9, 6] print(sorted(dic, key=lambda x: int(dic[x]))) print(sorted(lis, reverse=True))
- filter()函数,相当于是列表推导式中的筛选模式。map()函数,相当于是列表推导式中的循环模式,
# 5.filter函数 lis = [23, 4, 5, 1, 9, 6] def func(x): return x>6 f1 = filter(lambda x:x>6, lis) print(list(f1)) # [23, 9] print(list(filter(func, lis))) # [23, 9] # 6.map函数 f2 = map(lambda x: x+2, lis) print(list(f2)) # [25, 6, 7, 3, 11, 8]
2.2 常用函数
1、int(x, base=6),将x转成base进制的数
2、divmod(x, y),返回x除以y的商和余数。
3、round(2.8, 1),返回指定小数位数的浮点型
4、pow(base, index),幂指数
# 1、int int(3.5) # 3 float转int型 int('0100', base=2) # 4 其他base进制字符串转整型 # 2、divmod divmod(9, 2) # (4, 1) # 3、round round(3.14, 1) # 3.1 round(3.16, 1) # 3.2 # 4、base pow(2, 4) # 16
5、repr("python"),返回带有引号的字符串。
6、all(iterable),可迭代对象中全都是真则返回True。any(iterable),若有真就返回True
# 5、repr print(repr("python")) # 'python' # 6、all、any lis = [1, 2, '666', True] lis2 = [1, 2, '', True] all(lis) # True all(lis2) # False any(lis) # True any(lis2) # True
7、bytes(), 将字符串指定编码方式进行编码,如不懂编码,可以看***
# 7、bytes b1 = bytes(name, encoding='utf8') print(f"b1: {b1}, type: {type(b1)}") # b1: b'python', type: <class 'bytes'> print(bytes("西", encoding='gbk')) # b'\xce\xf7' print(bytes("西", encoding='utf8')) # b'\xe8\xa5\xbf'
3、闭包
闭包是什么?闭包是嵌套在函数中的函数,且对外层函数中的变量的引用。
def func(age): name = 'python' def inner(): print(name) print("内层函数 inner 被调用") return 'inner' return inner res = func(17) print(res) print(res()) # <function func.<locals>.inner at 0x7fbfe22f9550> # python # 内层函数 inner 被调用 #inner
闭包可以避免函数中的一些非全局变量被销毁,可以直接在内层函数中使用。
我觉得闭包其实就是为了后面的装饰器打基础的。
总结:
今天的重点是掌握一些重要的内置函数以及 lambada 匿名函数的用法,还是多看多练多总结!