python基础十
Posted 想成为大师啊
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python基础十相关的知识,希望对你有一定的参考价值。
函数的创建和调用
什么是函数:
- 函数就是执行特定任和以完成特定功能的一段代码
为什么需要函数
- 复用代码
- 隐藏实现细节
- 提高可维护性
- 提高可读性便于调试
函数的创建:
def 函数名([输入参数]):
函数体
[return ***]
函数的参数传递
函数调用的参数传递
- 位置实参:根据形参对应的位置进行实参传递
- 关键字实参:根据形参名称进行实参传递
def calc(a, b): # a,b称为形式参数,简称形参,形参的位置是在函数的定义处
c = a + b
return c
result = calc(10, 20) # 10,20称为实际参数的值,简称实参,实参的位置是函数的调用处
print(result)
res = calc(b=10, a=20)
print(res)
def fun(arg1, arg2):
print('arg1=', arg1) # arg1= 11
print('arg2=', arg2) # arg2= [22, 33, 44]
arg1 = 100
arg2.append(10)
print('arg1=', arg1) # arg1= 100
print('arg2=', arg2) # arg2= [22, 33, 44, 10]
n1 = 11
n2 = [22, 33, 44]
print(n1) # 11
print(n2) # [22, 33, 44]
print('------------')
fun(n1, n2) # 将位置传参, arg1,arg2是函数定义处的形参,n1,n2是函数调用处的实参,总结:实参名称与形参名称可以不一致
print(n1) # 11
print(n2) # [22, 33, 44, 10]
在函数调用过程中,进行参数的传递
如果是不可变对象,在函数体的修改不会影响实参的值 arg1的修改为100,不会影响n1的值
如果是可变对象,在函数体的修改会影响到实参的值 arg2的修改,append(10),会影响到n2的值
函数的返回值
- 如果函数没有返回值【函数执行完毕之后,不需要给调用处提供数据】return可以省略不写
- 函数的返回值,如果是1个,直接返回类型
- 函数的返回值,如果是多个,返回的结果为元组
def fun(num):
odd = [] # 存放奇数
even = [] # 存放偶数
for i in num:
if i % 2:
odd.append(i)
else:
even.append(i)
return odd, even
# 函数的调用
lst = [10, 29, 34, 23, 44, 53, 55]
print(fun(lst)) # ([29, 23, 53, 55], [10, 34, 44])
def fun1():
print('hello')
# return # 多此一举
fun1() # hello
def fun2():
return 'hello'
res = fun2()
print(res) # hello
def fun3():
return 'hello', 'world'
print(fun3()) # ('hello', 'world') 返回值类型是元组
函数在定义时,是否需要返回值(return),视情况而定
函数的参数定义
函数定义默认值参数
- 函数定义时,给形参设置默认值,只有与默认值不符的时候才需要传递实参
个数可变的位置参数
- 定义函数时,可能无法事先确定传递的位置实参的个数时,使用可变的位置参数
- 使用*定义个数可变的位置形参
- 结果为一个元组
个数可变的关键字形参
- 定义函数时,无法事先确定传递的关键字实参的个数时,使用可变的关键字形参
- 使用**定义个数可变的关键字形参
- 结果为一个字典
def fun(a, b=10):
print(a, b)
# 函数的调用
fun(100) # 100 10
fun(20, 30) # 20 30
def fun(*args): # 函数定义时的可变的位置参数
print(args)
# print(args[0])
fun(10) # (10,)
fun(10, 30) # (10, 30)
fun(30, 405, 50) # (30, 405, 50)
def fun1(**args):
print(args)
fun1(a=10) # {'a': 10}
fun1(a=20, b=30, c=40) # {'a': 20, 'b': 30, 'c': 40}
print('hello', 'world', 'java') # hello world java
"""
def fun(*args, *a):
pass
以上代码,程序会报错,个数可变的位置参数,只能是1个
def fun2(**args, **args):
pass
以上代码,程序会报错,个数可变的关键字参数,只能是1个
"""
def fun2(*args1, **args2):
pass
"""
def fun3(**args1, *arg2):
pass
在一个函数的定义过程中,既有个数可变的关键字形参,也有个数可变的位置形参,要求:个数可变的位置形参,放在个数可变的关键字形参之前
"""
函数的参数总结
- 位置实参 函数的调用(√)
- 将序列中的每个元素都转换为位置实参 函数的调用(√) 备注(使用*)
- 关键字实参 函数的调用(√)
- 将字典中的每个键值对都转换为关键字实参 函数的调用(√) 备注(使用**)
- 默认值形参 函数的定义(√)
- 关键字形参 函数的定义(√) 备注(*)
- 个数可变的位置形参 函数的定义(√) 备注(使用*)
- 个数可变的关键字形参 函数的定义(√) 备注(使用**)
def fun(a, b, c):
print('a=', a)
print('b=', b)
print('c=', c)
# 函数的调用
fun(10, 20, 30) # 函数调用时的参数传递,称为位置传参
lst = [11, 22, 33]
fun(*lst) # 函数调用时,将列表中的每个元素都转换为位置实参传入
print('--------------------')
fun(a=100, c=300, b=200)
dic = {'a': 111, 'b': 222, 'c': 333}
fun(**dic) # 在函数调用时,将字典中的键值对都转换为关键字实参传入
def fun(a, b=10): # b是在函数的定义处,所以b是形参,而且进行了赋值,所以b称为默认值形参
print('a=', a)
print('b=', b)
def fun2(*args): # 个数可变的位置形参
print(args)
def fun3(**args2): # 个数可变的关键字形参
print(args2)
fun2(10, 20, 30, 40) # (10, 20, 30, 40)
fun3(a=11, b=22, c=33, d=44, e=55) # {'a': 11, 'b': 22, 'c': 33, 'd': 44, 'e': 55}
def fun4(a, b, *, c, d): # 从*之后的参数,在函数调用时,只能采用关键字参数传递
print('a=', a)
print('b=', b)
print('c=', c)
print('d=', d)
# 调用fun4函数
# fun4(10, 20, 30, 40) # 位置实参传递
fun4(a=10, b=20, c=30, d=40) # 关键字实参传递
fun4(10, 20, c=30, d=40) # 前2个参数,采用的是位置实参传递,而从,d采用的是关键字实参传递
"""需求:c,d只能采用关键字实参传递"""
"""函数定义时的形参的顺序问题"""
def fun5(a, b, *, c, d, **args):
pass
def fun6(*args, **args2):
pass
def fun7(a, b=10, *args, **args2):
pass
变量的作用域
程序代码能访问该变量的区域
根据变量的有效范围可分为
- 局部变量:在函数内定义并使用的变量,只在函数内部有效,局部变量使用global声明,这个变量就会就成全局变量
- 全局变量:函数体外定义的变量,可作用于函数内外
def fun(a, b):
c = a+b # c 称为局部变量,因为c是在函数体内进行定义的变量,a,b为函数的形参,作用范围也是函数内部,相当于局部变量
print(c)
# print(c) 因为a,c超出了起作用的范围(超出了作用域)
# print(a)
name = '杨老师'
print(name)
def fun():
print(name)
fun()
def fun1():
global age # 函数内部定义的变量,局部变量,局部变量使用global声明,这个变量实际上就变成了全局变量
age=20
print(age)
fun1()
print(age)
递归函数
什么是递归函数
- 如果在一个函数的函数体内调用了该函数本身,这个函数就称为递归函数
递归的组成部分
- 递归调用与递归终止条件
递归的调用过程
- 每递归调用一次函数,都会在栈内存分配一个栈帧
- 每执行完一次函数,都会释放相应的空间
递归的优缺点
- 缺点:占用内存多,效率低下
- 优点:思路和代码简单
def fac(n):
if n==1:
return 1
elif n==2:
return 1
else:
return fac(n-2)+fac(n-1)
# 斐波那契数列第6位上的数字
print(fac(6))
print('---------------------')
# 输出这个数列的前6位上的数字
for i in range(1, 7):
print(fac(i))
以上是关于python基础十的主要内容,如果未能解决你的问题,请参考以下文章