函数声明为了代码的可读性,在定义一个函数的时候,最好有其函数参数的说明。示例:def func_test(s): """ :type s: str :rtype: str """ pass实现这种效果可以通过插件设置,比如在vscode里面,我们可以使用 koroFileHeader 来实现这样的功能,直接在vscode搜索安装即可,然后根据其 github 里面的说明进行配置函数的参数Python中函数的参数有四种,分别是:位置参数默认参数可变参数关键字参数python 按照参数的位置来区别参数,位置参数的优先级是最高的,其次分别是默认参数,可变参数,关键字参数def f1(a, b, c=0, *args, **kw): print(‘a =’, a, ‘b =’, b, ‘c =’, c, ‘args =’, args, ‘kw =’, kw)可变参数将传入的参数包装成一个tuple,关键字参数将传入的参数包装成一个dict,因此在函数中使用这些参数的时候,可以使用 args 或者 kw 这样的关键字来使用其中的值,因为在函数声明的时候,是以这两个关键字声明的。高阶函数下面几个函数在大多数编程语言里面都有,属于高阶函数,它们接受函数作为其中的参数:mapreducefiltersorted这些函数涉及到python的一个概念,iterator 和 iterableIterator 和 Iterable 的区别Iterator 是惰性的,也就是说,一开始并不知道 下一个数是多少,只有使用了next ,它才会去计算下一个数,这样的好处是什么呢?这样就保证了不会一次性将大量的数据带到内存里面计算,只有用到的时候,在去计算Iterable 则是相反的,它会一次把所有的数据全部带到内存里面,其中list,dict,tuple 都是Iterable 而不是 Iteratormapmap()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回。代码:>>> def f(x):… return x * x…>>> r = map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])>>> list(r)[1, 4, 9, 16, 25, 36, 49, 64, 81]reducereduce 把一个函数作用在一个序列[x1, x2, x3, …]上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算filterfilter 也接收一个函数和一个序列。和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是True还是False决定保留还是丢弃该元素sortedsorted 函数也是一个高阶函数,它还可以接收一个key函数来实现自定义的排序匿名函数>>> list(map(lambda x: x * x, [1, 2, 3, 4, 5, 6, 7, 8, 9]))[1, 4, 9, 16, 25, 36, 49, 64, 81]装饰器装饰器是Python里面非常有用的黑魔法,在许许多多的地方都会使用到装饰器,从而使代码复用,举一个例子,假如存在有多个函数,调用每个函数的时候,都需要经过认证,最好的做法就是把认证的代码写成一个装饰器,然后加在每一个函数的开头。#coding:utf-8import functoolscert = { “username”:“test”, “password”:“qwe123”}def authentication(func): @functools.wraps(func) def wrapper(*args,**kw): if cert[“username”] == “test” and cert[“password”] == “qwe123”: return func(*args,**kw) else: print(“auth failed”) return wrapper@authenticationdef user_profile(): print(“Hello Here is user profile”)if name == “main”: user_profile()装饰器函数的代码有一定的规律,写起来大同小异,只是其中的业务逻辑不同。