函数就是执行特定任和以完成特定功能的一段代码
复用代码
隐藏实现细节
提高可维护性
提高可读性便于调试





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)
print(bool(0)) #False
print(bool(8)) #非0的布尔值为True
根据形参对应的位置进行实参传递

根据形参名称进行实参传递

函数调用的参数传递内存分析图


def fun(arg1,arg2):
print('arg1',arg1)
print('arg2',arg2)
arg1=100
arg2.append(10)
print('arg1',arg1)
print('arg2',arg2)
#return
n1=11
n2=[22,33,44]
print('n1',n1)
print('n2',n2)
fun(n1,n2) #将位置传参 ,arg1,arg2,是函数定义处的形参,n1,n2是函数调用的处的实参 ,总结,实参名称与形参名称可以不一致
print('n1',n1)
print('n2',n2)
'''在函数调用过程中,进行参数的传递
如果是不可变对象, 在函数体的修改不会影响实参的值 arg1的修改为100,不会影响n1的值
如果是可变对象,在函数体的的修改会影响到实参的值 arg2的修改,append(10),会影响到n2的值
'''
函数返回多个值时,结果为元组


print(bool(0)) #False
print(bool(8)) #非0的布尔值为True
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))
'''
函数的返回值
(1)如果函数没有返回值【函数执行完毕之后,不需要给调用处提供数据】 return可以省略不写
(2)函数的返回值,如果是1个,直接返回类型
(3)函数的返回值,如果是多个,返回的结果为元组
'''
def fun1():
print('hello')
#return
fun1()
def fun2():
return 'hello'
res=fun2()
print(res)
def fun3():
return 'hello','world'
print(fun3())
'''函数在定义时,是否需要返回值,视情况而定'''
函数定义时,给形参设置默认值,只有与默认值不符的时候才需要传递实参

def fun(a,b=10): #b称为默认值参数
print(a,b)
#函数的调用
fun(100)
fun(20,30)
print('hello',end='\t')
print('world')
定义函数时,可能无法事先确定传递的位置实参的个数时,使用可变的位置参数
使用*定义个数可变的位置形参
结果为一个元组

定义函数时,无法事先确定传递的关键字实参的个数时,使用可变的关键字形参
使用**定义个数可变的关键字形参
结果为一个字典

def fun(*args): #函数定义时的 可变的位置参数
print(args)
#print(args[0])
fun(10)
fun(10,30)
fun(30,405,50)
def fun1(**args):
print(args)
fun1(a=10)
fun1(a=20,b=30,c=40)
print('hello','world','java')
'''def fun2(*args,*a):
pass
以上代码,程序会报错,个数可变的位置参数,只能是1个
def fun2(**args,**args):
pass
以上代码,程序会报错,个数可变的关键字参数,只能是1个
'''
def fun2(*args1,**args2):
pass
'''def fun3(**args1,*arg2):
pass
在一个函数的定义过程中,既有个数可变的关键字形参,也有个数可变的位置形参,要求,个数可变的位置形参,放在个数可变的关键字形参之前
'''
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)
fun3(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) #前两个参数,采用的是位置实参传递,而c,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='杨老师' #name的作用范围为函数内部和外部都可以使用 -->称为全局变量
print(name)
def fun2():
print(name)
#调用函数
fun2()
def fun3():
global age #函数内部定义的变量,局部变量,局部变量使用global声明,这个变量实际上就变成了全局变量
age=20
print(age)
fun3()
print(age)

世界上第一部万用计算机的进化版-马克2号(Mark II)


Bug的常见类型
粗心导致的语法错误 SyntaxError
(1)

(2)

(3)

age=input('请输入你的年龄')
print(type(age))
if int(age)>=18:
print('成年人...')
i=0
while i <10:
print(i)
i+=1
粗心导致错误的自查宝典
1.漏了末尾的冒号,如if语句,循环语句,else子句等
2.缩进错误,该缩进的没缩进,不该缩进的瞎缩进
3.把英文符号写成中文符号,比如说:引号,冒号,括号
4.字符串拼接的时候,把字符串和数字拼在一起
5.没有定义变量,比如说while的循环条件的变量
6.**“==”比较运算符和”=”**赋值运算符的混用


lst=[11,22,33,44] #列表的索引是从0开始,
#print(lst[4])
print(lst[3])
lst=[]
#lst=append('A','B','C')
lst.append('A')
lst.append('B')
lst.append('C')
print(lst)
(1)使用print()函数
(2)使用”#”暂时注释部分代码
题目要求
豆瓣电影Top250排行,使用列表存储电影信息,
要求输入名字在屏幕上显示xxx出演了哪部电影。

lst=[{'rating':[9.7,2062397],'id':'1292052','type':['犯罪','剧情'],'title':'肖申克的救赎','actors':['蒂姆·罗宾斯','摩根·弗里曼']},
{'rating':[9.6,1528760],'id':'1291546','type':['剧情','爱情','同性'],'title':'霸王别姬','actors':['张国荣' ,'张丰毅' , '巩俐' ,'葛优']},
{'rating':[9.5,1559181],'id':'1292720','type':['剧情','爱情'],'title':'阿甘正传','actors':['汤姆·汉克斯','罗宾·怀特 ']}
]
name=input('请输入你要查询的演员:')
for item in lst: #遍历列表 -->{} item是一个又一个的字典
act_lst=item['actors']
for actor in act_lst:
if name in actor:
print(name,'出演了',item['title'])
'''
for movie in item: #遍历字典,得到movie 是一个字典中的key
print(movie)
print('-----------------------')
actors=movie['actors']
if name in actors:
print(name+'出演了:'+movie)
'''



程序代码逻辑没有错,只是因为用户错误操作或者一些“例外情况”而导致的程序崩溃
题目要求:输入两个整数并进行除法运算

a=int(input('请输入第一个整数'))
b=int(input('请输入第二个整数'))
result=a/b
print('结果为:',result)
Python提供了异常处理机制,可以在异常出现时即时捕获,然后内部“消化”,让程序继续运行


try:
a=int(input('请输入第一个整数'))
b=int(input('请输入第二个整数'))
result=a/b
print('结果为:',result)
except ZeroDivisionError:
print('对不起,除数不允许为0')
print('程序结束')
多个except结构

try…except…else结构
如果try块中没有抛出异常,则执行else块,如果try中抛出异常,则执行except块

try:
a = int(input('请输入第一个整数'))
b = int(input('请输入第二个整数'))
result = a / b
except BaseException as e:
print('出错了',e)
else:
print('计算结果为:',result)
try…except…else…finally结构
finally块无论是否发生异常都会被执行,能常用来释放try块中申请的资源

try:
a = int(input('请输入第一个整数'))
b = int(input('请输入第二个整数'))
result = a / b
except BaseException as e:
print('出错了',e)
else:
print('计算结果为:',result)
finally:
print('谢谢您的使用')

