python基础四:函数
def sum(a,b):
result = a+b
print(result)
num1 = int(input("num1:"))
num2 = int(input("num2:"))
sum(num1,num2)
a,b为形参,形参不占内存空间
def test():
a = 11
b = 22
c = 33
return a
return b
return c
num = test()
print(num)
#注意:函数只要return了,那么函数也就执行完成了,所以上面的return b,c都是不会执行的
总结:
返回值数=0:返回None
返回值数=1:返回object
返回值数>1:返回tuple
wendu = 0
def get_wendu():
global wendu
#使用global用来对一个全局变量的声明,那么这个函数中的wendu=33就不是定义一个局部变量,
#而是对全局变量进行修改
wendu = 33
def print_wendu():
print("温度是%d" % wendu)
get_wendu()
print_wendu()
全局变量的位置:
a = 100
def test():
print("a = %d" % a)
print("b = %d" % b)
print("c = %d" % c)
b = 200
test()
c = 300
输出结果为:
a = 100
b = 200
Traceback (most recent call last):
File "test.py", line 7, in <module>
test()
File "test.py", line 5, in test
print("c = %d" % c)
NameError: name 'c' is not defined
由上面输出的结果可知全局变量定义的位置只要定义在函数调用之前即可被函数使用!
全局变量与局部变量重名的问题:
a = 100
def test():
a = 200
print("a = %d" % a)
def test2():
print("a = %d" % a)
test()
test2()
输出结果:
a = 200
a = 100
从上面的输出结果可知:函数内定义的变量只要前面没有加global那么该变量就是局部变量,函数内会优先读取局部变量!
def sum_2_nums(a,b,*args):
print(a)
print(b)
print(args)
sum_2_nums(11,22,33,44,55)
输出结果:
11
22
(33, 44, 55)
上面输出的(33,44,55)就是*args参数
这里注意:
如果上面的函数传递的参数是sum_2_nums(11,22,33),那么在打印args参数时会输出(33,),元组中如果只有一个元素,那么后面的逗号不能省略
args参数必须放在最所有形参数的最后面
def test(a,b,c=33,*args,**kwargs):
print(a)
print(b)
print(c)
print(args)
print(kwargs)
test(11,22,33,44,['a','b'],{"name":"Poe","age":18},task=99,done=89)
输出结果:
11
22
33
(44, ['a', 'b'], {'name': 'Poe', 'age': 18}) #args
{'done': 89, 'task': 99} #kwargs
**kwargs对应实参中带变量名的传参!
如何取args参数中的值:
def test(a,b,c=33,*args ):
print("="*30)
print(a)
print(b)
print(c)
print(args)
result = a + b
for num in args:
result += num
print("result = %d" % result)
test(11,22,33,44,66,99)
test(11,22)
test(11,22,33)
输出结果:
==============================
11
22
33
(44, 66, 99)
result = 242
==============================
11
22
33
()
result = 33
==============================
11
22
33
()
result = 33
先来看一个函数:
def test(a,b,c=33,*args,**kwargs):
print(a)
print(b)
print(c)
print(args)
print(kwargs)
A = (44,55,66)
B = {"name":"Poe","age":18}
test(11,22,33,A,B)
输出结果:
11
22
33
((44, 55, 66), {'age': 18, 'name': 'Poe'})
{}
从上面的输出结果可知:A的元组与B的字典当做参数传到函数时,对应的形参是args,现在的需求是让A变量对应args参数,让B变量对应*kwargs参数,如何做呢?
在调用函数时:test(11,22,33,A,**B)
输出结果:
11
22
33
(44, 55, 66)
{'name': 'Poe', 'age': 18}
实参中一个号的作用是将元组进行拆包,拆成44,55,66传递给形参,二个号的作用是将字典拆包,拆成KEY=VALUE传递给形参,有多少个就拆成多少个
python中除了数字,字符串,元组是不可变类型,其它的都是可变类型
可变类型在字典中不允许当作键,因为字典的保存方法比较特殊,如:
info = {"name":"Poe",100:"haha"}
在保存时会将键name哈希成一个值,比如:12121212,再保存这个哈希值与value值
def getNums(num):
if num == 1:
return 1
result = num * getNums(num-1)
return result
result = getNums(4)
print(result)
上面函数的执行过程:
递归的问题:
一定要有递归的出口,否则函数会一直执行,直到内存被占满,最后溢出!
先来看一段代码:
nums = [11,22,3,1,5,665,34,64,2]
nums.sort()
print(nums)
输出结果:
[1, 2, 3, 5, 11, 22, 34, 64, 665]
nums = [11,22,3,1,5,665,34,64,2]
nums.sort()
print(nums)
nums.sort(reverse=True)
print(nums)
输出结果:
[1, 2, 3, 5, 11, 22, 34, 64, 665]
[665, 64, 34, 22, 11, 5, 3, 2, 1]
那么如果一个列表中所有的元素都是字典呢?如何按字典中的键或值来排序呢?
infos = [
{"name":"Poe","age":20},
{"name":"Andy","age":19},
{"name":"Jet","age":21}
]
infos.sort(key=lambda x:x['name'])
print(infos)
输出结果:
[{'age': 19, 'name': 'Andy'}, {'age': 21, 'name': 'Jet'}, {'age': 20, 'name': 'Poe'}]
如果要按字典中的age进行排序呢?
infos.sort(key=lambda x:x['age'])
def test(a,b,func):
result = func(a,b)
return result
num = test(11,22,lambda x,y:x+y)
print(num)
匿名函数的应用:
def test(a,b,func):
result = func(a,b)
return result
func_new = input("请输入一个匿名函数:")
func_new = eval(func_new) #将输入进来的字符串:lambda x,y:x+y变成一个函数
num = test(11,22,func_new)
print(num)
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341