接下来,咱们将按照这个函数体系给你们详细的介绍函数:python
* 什么是函数?
* 为何要用函数?
* 函数的分类:内置函数与自定义函数
* 如何自定义函数
1.语法
2.定义有参数函数,及有参函数的应用场景
3.定义无参数函数,及无参函数的应用场景
4.定义空函数,及空函数的应用场景
* 调用函数
1.如何调用函数
2.函数的返回值
3.函数参数的应用:形参和实参,位置形参,位置实参,关键字实参,默认形参,*args,**kwargs编程
* 高阶函数(函数对象)
* 函数嵌套
* 做用域与名称空间
* 装饰器
* 迭代器与生成器及协程函数
* 三元运算,列表解析、生成器表达式
* 函数的递归调用
* 内置函数
* 面向过程编程与函数式编程函数式编程
假设如今你是下水道工,若是你事先准备好你的工具箱,等你接到修理下水道的工做的时候,你直接把你的工具箱拿过去直接使用就好了,而不须要临时准备锤子啥的。函数
在程序中,函数就是具有某一功能的工具,事先将工具准备好就是函数的定义,遇到应用场景拿来就用就是函数的调用.
总结:函数是事先准备好的具有一些功能的工具,能够很大程度上提升开发者的开发效率.工具
若是不使用函数,写程序时将会遇到这三个问题:code
1.程序冗长
2.程序的扩展性差
3.程序的可读性差协程
先定义函数,后调用。
* 定义函数对象
def 函数名(param一、param2……): """ 函数功能的描述信息 :param1:描述 :param2:描述 :return:返回值 """ code 1 code 2 code 3 ... return 返回值
我的大白话:完整函数体要有def 函数名(参数): 函数注释 函数体代码 函数返回值(默认返回None,目前接触2种形式yield(-->动态返回),return,默认不写都是 return None 还有就是下面的函数的调用部分!)
* 调用函数递归
函数名(param一、param2……)
我的大白话:在函数名后加()就是调用该函数,实质上上就是执行函数名所指向的存放函数地址的信息ip
# 注册功能函数 def register(): """注册功能""" username = input('username: ').strip() pwd = input('password: ').strip() with open('38a.txt', 'a', encoding='utf8') as fa: fa.write(f"{username}:{pwd}\n") fa.flush() register() # 复用 register() register()
# 登陆功能函数 def login(): """登陆功能""" inp_username = input('username: ').strip() inp_pwd = input('password: ').strip() with open('38a.txt', 'rt', encoding='utf8') as fr: for user_info in fr: user_info = user_info.strip('\n') user_info_list = user_info.split(':') if inp_username == user_info_list[0] and inp_pwd == user_info_list[1]: print('login successful') break else: print('failed') login()
def func(): bar() # 不属于语法错误,不会报错 print('*'*10)
重点: 函数定义阶段只检测语法,不执行函数体代码!!!
def bar(): print('from bar') def foo(): print('from foo') bar() foo() ''' from foo from bar '''
def foo(): print('from foo') bar() def bar(): print('from bar') foo() ''' from foo from bar '''
函数名() ---> 调用