1. 函数简介
1.1 什么是函数
- 具有独立功能的代码块组织为一个小模块,这就是函数
1. 2 函数格式
1. def 函数名(): 2. 代码
1.3 调用方式
- 函数名()
1. # -*- coding: utf-8 -*- 2. # @Time : 2021/2/6 3. # @Author : 大海 4. 5. # 定义函数 6. def fib(n): 7. """斐波那契数列""" 8. a, b = 0, 1 9. while a < n: 10. print(a) 11. a, b = b, a + b 12. 13. 14. # 调用函数 15. fib(10)
1.4 匿名函数
- 使用:
lambda关键字用于创建小巧的匿名函数 - 格式:lambda 参数:表达式
1. # -*- coding: utf-8 -*- 2. # @Time : 2021/2/6 3. # @Author : 大海 4. 5. f = lambda x: x ** 2 6. print(f(2)) 7. 8. pairs = [(1, 'one'), (2, 'two'), (3, 'three'), (4, 'four')] 9. print(pairs.sort(key=lambda pair: pair[1]))
2. 函数参数
- 定义时小括号中的参数,用来接收参数用的,称为 “形参”
- 调用时小括号中的参数,用来传递给函数用的,称为 “实参”
2.1 默认值参数(缺省参数)
- 在形参中默认有值的参数,称之为缺省参数
1. # -*- coding: utf-8 -*- 2. # @Time : 2021/2/6 3. # @Author : 大海 4. 5. def ask_ok(prompt, retries=4, reminder='Please try again!'): 6. while True: 7. ok = input(prompt) 8. if ok in ('y', 'ye', 'yes'): 9. return True 10. if ok in ('n', 'no', 'nop', 'nope'): 11. return False 12. retries = retries - 1 13. if retries < 0: 14. raise ValueError('invalid user response') 15. print(reminder) 16. 17. 18. # 只给出必选实参: 19. ask_ok('Do you really want to quit?') 20. 21. # 给出一个可选实参: 22. ask_ok('OK to overwrite the file?', 2) 23. 24. # 给出所有实参: 25. ask_ok('OK to overwrite the file?', 2, 'Come on, only yes or no!')
- 默认值为不可变类型在定义作用域里的函数定义中求值
1. # -*- coding: utf-8 -*- 2. # @Time : 2021/2/6 3. # @Author : 大海 4. # 默认值为不可变类型在定义作用域里的函数定义中求值 5. i = 5 6. 7. 8. def f(arg=i): 9. print(arg) 10. 11. 12. i = 6 13. f() # 5
- 默认值为列表、字典或类实例等可变对象时
1. # -*- coding: utf-8 -*- 2. # @Time : 2021/2/6 3. # @Author : 大海 4. # 可变类型作为默认参数 5. def f(a, list_one=[]): 6. list_one.append(a) 7. return list_one 8. 9. 10. print(f(1)) 11. print(f(2)) 12. print(f(3)) 13. 14. 15. # 后续调用之间共享默认值 16. def f(a, list_two=None): 17. if list_two is None: 18. list_two = [] 19. list_two.append(a) 20. return list_two 21. 22. 23. print(f(1)) 24. print(f(2)) 25. print(f(3))
2.2 不定长参数
- 加了星号(*)的变量args会存放所有未命名的变量参数,args为元组
- 而加**的变量kwargs会存放命名参数,即形如key=value的参数, kwargs为字典.
- 不定长参数放在参数最后
1. # -*- coding: utf-8 -*- 2. # @Time : 2021/2/6 3. # @Author : 大海 4. 5. # -*- coding: utf-8 -*- 6. # @Time : 2021/2/6 7. # @Author : 大海 8. def fun(a, b, *args, **kwargs): 9. """可变参数演示示例""" 10. print("a =%d" % a) 11. print("b =%d" % b) 12. print("args:") 13. print(args) 14. 15. print("kwargs: ") 16. for key, value in kwargs.items(): 17. print("key=%s" % value) 18. 19. 20. fun(1, 2, 3, 4, 5, m=6, n=7, p=8) 21. 22. c = (3, 4, 5) 23. d = {"m": 6, "n": 7, "p": 8} 24. fun(1, 3, *c, **d)
2.3 特殊参数
- 格式及说明:
/和*是可选的。这些符号表明形参如何把参数值传递给函数:位置、位置或关键字、关键字
1. def f(pos1, pos2, /, pos_or_kwd, *, kwd1, kwd2): 2. ----------- ---------- ---------- 3. | | | 4. | 位置参数或关键字参数 | 5. | - 只能是关键字参数 6. -- 只能是位置参数
2.3.1 仅限位置参数
- 使用:仅限位置形参应放在
/(正斜杠)前。/用于在逻辑上分割仅限位置形参与其它形参。如果函数定义中没有/,则表示没有仅限位置形参。
2.3.2 仅限关键字参数
- 把形参标记为 仅限关键字,表明必须以关键字参数形式传递该形参,应在参数列表中第一个 仅限关键字 形参前添加
*
1. # -*- coding: utf-8 -*- 2. # @Time : 2021/2/6 3. # @Author : 大海 4. 5. # 未使用 / 和 * 时,参数可以按位置或关键字传递给函数 6. def standard_arg(arg): 7. print(arg) 8. 9. 10. standard_arg('我是测试小白') 11. standard_arg(arg='我是测试小白') 12. 13. 14. # 仅限位置参数 15. def pos_only_arg(arg, /): 16. print(arg) 17. 18. 19. pos_only_arg('我是测试小白') 20. 21. 22. # 仅限位置参数,当做关键字参数传参会报错 23. # pos_only_arg(arg='a') 24. 25. # 仅限位置参数 26. def kwd_only_arg(*, arg): 27. print(arg) 28. 29. 30. kwd_only_arg(arg='我是测试小白') 31. 32. 33. # 仅限位置和关键字参数同时存在 34. def combined_example(pos_only, /, standard, *, kwd_only): 35. print(pos_only, standard, kwd_only) 36. 37. 38. combined_example(1, 2, kwd_only=3) 39. combined_example(1, standard=2, kwd_only=3)