python的函数介绍 位置参数 关键字参数 默认参数 参数组 *args **kwargs
1、数学意义的函数与python中的函数
数学意义的函数
y = 2*3+1
x =3
y =7
x是自变量,y是因变量
2、python中定义函数的方法
一个函数往往都是为了完成一个特定的功能而存在的,所以注释信息加上是个好习惯
def atest(x):
"The function definitions"
x += 1
return x
def: 定义函数的关键字
atest: 函数名
(): 内可定义形参
"": 文档描述(非必要,但是强烈建议为你的函数添加描述信息)
x+=1: 泛指代码块或程序处理逻辑
return: 定义返回值
没有return也是可以的,一个函数里面只要运行到return就会退出整个函数,不在继续往下走
调用运行:可以带参数也可以不带
函数名()
3、写一个函数
def atest(x):
"""
2*x+1
:param x: 整形数字
:return: 返回计算结果
"""
y=2*x+1
return
y
print (atest)
打印出来的是函数的内存地址
<function test at 0x0000000001556D90>
调用下函数
def atest(x):
"""
2*x+1
:param x: 整形数字
:return: 返回计算结果
"""
y = 2 * x + 1
return y
a = atest(3)
print(a) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 7
4.什么情况下调用函数的时候不用加参数呢,就是定义函数的时候括号里面为空
def atest():
"""
2*x+1
:param x: 整形数字
:return: 返回计算结果
"""
x = 3
y = 2 * x + 1
return y
a = atest()
print(a) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 7
5、同一个文件里面的函数名不能有相同的函数名,如果有2个相同的函数名,在下面调用代码的时候会先最终调用最下面的函数,因为python执行顺序是从上到下的,上面的函数会被下面的函数覆盖掉
6.函数的好处
函数的好处:
代码重用
保持一致性,易维护
可扩展性
7.过程定义
过程就是简单特殊没有返回值的函数
下面这atest01就是过程,atest02就是函数
def atest01():
msg="hello the little green frog"
print (msg) def atest02():
msg="hello beiye"
print (msg)
return msg
t1=atest01()
t2=atest02() C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py hello the little green frog hello beiye
8.return可以返回多个值,其实也是一个值,是一个元组
def atest01():
msg="test01"
print (msg)
def atest02():
msg="test02"
print (msg)
return msg
def atest03():
msg="test03"
print (msg)
return 1,2,3,"gou",["beiye"],None,{"name":"gou"}
t1=atest01()
t2=atest02()
t3=atest03()
print (t1)
print (t2)
print (t3) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py test01 test02 test03 None test02 (1, 2, 3, 'gou', ['beiye'], None, {'name': 'gou'})
总结:
返回参数=0:返回None
返回参数=1:返回object
返回值数>1:返回tuple 元组
9.函数的参数
分为2种,形参 实参
(1)形参变量只有在被调用的时候才分配内存单元。因此形参只在函数内部有效。函数调用结束返回主调用函数后则不能再使用该形参变量
(2)实参可以是常量、变量、表达式、函数等,无论实参是何种类型的变量,在进行函数调用时,他们都必须有确定的值,以便把这些值传送给形参,因此预先赋值,输入等办法使参数获得确定值
上面的说法听不懂,我自己说下,
形参就是定义函数的时候()里面的定义的参数,还没有被使用,只是定义好
实参就是函数定义完成了,在下面进行调用的时候传进去的参数
def cacl(x, y): #定义了一个函数cacl 形参是x y
reus = x ** y #reus = x的y次方
return reus
reus = cacl(2, 5) #把2传值给x,把5传值给y
print(reus) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 32
(3)位置参数,形参和实参位置必须一一对应,多传参数和少传参数都不行
这个函数的功能就是传入什么参数就打印出来什么
def reus(x,y,z): #x y z是3个形参
print(x)
print(y)
print(z)
reus(1,2,3)#因为形参是三个,所以实参也得是3个,得一一对应,不然就会报错 C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 2 3
我们试下形参是3个,实参传2个试试(直接报错了,也就是说少传参数是不行的)
def reus(x,y,z):
print(x)
print(y)
print(z)
reus(1,2) TypeError: reus() missing 1 required positional argument: 'z'
required [rɪ'kwaɪəd] 必须的
positional [pəˈzɪʃənəl] 位置
(4)关键字参数,传参数的时候给指定的形参赋值,并不需要考虑位置的先后顺序,只要形参和实参的个数是一一对应的就可以,多传参数和少传参数都不行
def reus(x,y,z):
print(x)
print(y)
print(z)
reus(y=5,x=4,z=6) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py
4
5
6
(5)位置参数和关键字参数混合使用
位置参数必须在关键字参数左边
def reus(x,y,z):
print(x)
print(y)
print(z)
reus(4,y=5,z=6) #4就是位置参数,y=5,z=6就是关键字参数 C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py
4
5
6
这个位置参数也是在关键字参数左边,为什么报错呢?
因为传参数的时候,第一个参数4赋值给了x,第二个参数6赋值给了y,第三个又传给了y的值等于5, 我们翻译下报错信息就是,这个reus函数的y参数被赋了多个值,所以这里就知道了,一个形参是不能被传参多次的
def reus(x,y,z):
print(x)
print(y)
print(z)
reus(4,6,y=5) TypeError: reus() got multiple values for argument 'y'
multiple [ˈmʌltɪpl] 多个
(6)默认参数
y="linux"就是默认参数,如果传参的时候不传这个参数就使用默认的,如果传入的话就使用传入的值
def reus(x,y="linux"):
print(x)
print(y)
reus(4) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 4 linux
这里为什么把66也括起来呢,因为上面的默认参数就是一个字符串,下面实参也要是字符串
def reus(x,y="linux"):
print(x)
print(y)
reus(4,"") C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 4 66
(7)参数组 **字典 *列表 (也叫可变长参数)
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
print (args)
atest(1,2,3,4,5,6) #1传入x,剩下的都传给args了当成一个元组的方式打印出来了 C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 (2, 3, 4, 5, 6)
(7).1还能按照索引的方式打印,这就是非固定长度的参数
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
print (args)
print(args[0])
atest(1,2,3,4,5,6) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 (2, 3, 4, 5, 6) 2
(7).2也可以传入多个值给args,但是函数中并不处理这个args,也是可以的
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
atest(1,2,3,4,5,6) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1
也可不传
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
print(args)
atest(1) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 ()
(7).3如果给args传入的是2个列表呢
他会把这2个列表作为2个整体传给args,然后以元组的方式打印出来,这2个列表作为这个元组的2个元素
a=[22,33,44,55,66]
b=["heh","beiye"]
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
print(args)
atest(1,(a),(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 ([22, 33, 44, 55, 66], ['heh', 'beiye'])
传入2个字典也是一样的
他会把这2个字典作为2个整体传给args,然后以元组的方式打印出来,这2个字典作为这个元组的2个元素
a={"name":"gou"}
b={"age":28}
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
print(args)
atest(1,(a),(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 ({'name': 'gou'}, {'age': 28})
(7).4问题来了,如果我不想让列表和字典作为一个整体传给args呢,而是遍历一下传给args
列表的时候应该怎么遍历呢
传入参数是列表的时候用1个*(传参数是元组也是用一个*就不举例子了)
下面的第一个实参 "哈哈"传给了x,
a和b这2个参数是2个列表传给了args,传列表用一个* 这是固定用法,传字典用2个
a=[1,2,3]
b=[4,5,6]
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
print(args)
atest("哈哈",*(a),*(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 哈哈 (1, 2, 3, 4, 5, 6)
要想取到列表中的6这个元素该怎么取(索引方式就可以取到了)
a=[1,2,3]
b=[4,5,6]
def atest(x,*args): #args 是第二个形参 *是一个特殊用法
print (x)
print(args[5])
atest("哈哈",*(a),*(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 哈哈 6
(7).5传入参数是字典的时候用2个* **kwargs
a={"name":"gou"}
b={"age":28}
def atest(x,**kwargs): #args 是第二个形参 *是一个特殊用法
print (x)
print(kwargs)
atest(1,**(a),**(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 {'name': 'gou', 'age': 28}
要想取到字典里面的28这个value应该怎么取呢
a={"name":"gou"}
b={"age":28}
def atest(x,**kwargs): #args 是第二个形参 *是一个特殊用法
print (x)
print(kwargs["age"])
atest(1,**(a),**(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 28 a={"name":"gou"}
b={"age":28}
def atest(x,**kwargs): #args 是第二个形参 *是一个特殊用法
print (x)
print(kwargs.get("age"))
atest(1,**(a),**(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 28
要想取到字典里面所有的value呢,就可以用字典的方法了
a={"name":"gou"}
b={"age":28}
def atest(x,**kwargs): #args 是第二个形参 *是一个特殊用法
print (x)
print(kwargs.values())
atest(1,**(a),**(b)) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 dict_values([28, 'gou'])
也可以这样写,最后也会以字典的方式打印出来
def atest(x,**args): #args 是第二个形参 *是一个特殊用法
print (x)
print(args)
atest(1,y=2,z=3) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 {'z': 3, 'y': 2}
(7).6
*args **kwargs 两者连接起来使用,无所不能,可以接受任意长度的参数
def atest(x,*args,**kwargs):
print (x)
print(args)
print (kwargs)
atest(1,11,22,33,44,y=2,z=3) C:\python35\python3.exe D:/pyproject/day14函数/hanshu.py 1 (11, 22, 33, 44) {'y': 2, 'z': 3}
python的函数介绍 位置参数 关键字参数 默认参数 参数组 *args **kwargs的更多相关文章
- (转)python之函数介绍及使用
为什么要用函数? 1.减少代码量 2.保持一致性 3.易维护 一.函数的定义和使用 ? 1 2 3 4 5 6 def test(参数): ... 函数体 . ...
- python strip()函数 介绍
python strip()函数 介绍,需要的朋友可以参考一下 函数原型 声明:s为字符串,rm为要删除的字符序列 s.strip(rm) 删除s字符串中开头.结尾处,位于 rm删除 ...
- python中函数的定义、返回值以及参数的简要介绍
一. 1.函数 定义:def关键字开头,空格之后接函数名称和圆括号(),后面紧跟‘:”. 函数是对功能的封装 语法: def 函数名(形参列表): 函数体(代码块,return) 调用: 函数名(实参 ...
- day11 python学习 函数的建立,返回值,参数
函数的定义主要有如下要点: def:表示函数的关键字 函数名:函数的名称,日后根据函数名调用函数 函数体:函数中进行一系列的逻辑计算,如:发送邮件.计算出 [11,22,38,888,2]中的最大数等 ...
- Python在函数中使用列表作为默认参数
在学习中遇到的Python的一个坑,那就是使用列表作为默认参数. 我们知道,在Python中,列表(list)是可变对象,所以列表的内容可能会在函数内改变.另一个需要注意的是,使用列表作为函数的默认参 ...
- 移动端自动化测试(二)之 Appium常用的API(python)函数介绍
上一章节已经介绍了Appium的环境搭建,其实只要掌握了Appium的工作原理,前期的准备工作和安装过程是比较简单的.那么当我们搭建好Appium环境后接下来做些什么呢?通常思路是开始appium的第 ...
- python之函数形参、实参、可变长参数整体使用和分类
形参与实参 '''def fn(形参们): pass fn(实参们)'''# 形参:定义函数,在括号内声明的变量名,用来结束外界传来的值# 实参:调用函数,在括号内传入的实际值,值可以为常量.变量.表 ...
- python之函数介绍
# 函数 # 什么是函数: 能完成特定功能的工具,在Python中表示能完成特定功能的代码块.(函数定义) # 为什么要用函数 :①函数可以重复调用出来,效率高,而且维护成本低 ②使程序结构看起来清晰 ...
- python socket 函数介绍
socket 函数原型:socket.socket([family[,type[,proto]]]) family参数取值(协议族): socket.AF_INET -->ipv4 ...
随机推荐
- C++ Style Languages: C++, Objective-C, Java, C#
Hyperpolyglot.org From Hyperpolyglot.org C++ Style Languages: C++, Objective-C, Java, C# a side-by-s ...
- CentOS赋予一个普通用户root权限
http://www.linuxidc.com/Linux/2012-07/64530.htm
- 微信公众号开发笔记1(nodejs开发)
本篇记录了微信公众号开发的一些笔记 一.微信服务器与我们服务器的交流 微信开发者拥有自己的服务器,在我们服务器上可以与微信服务器进行交流.既然可以交流,那就必定需要前提条件(微信认证),也就是说,只有 ...
- Scrum立会报告+燃尽图(十月十一日总第二次):需求分析
此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2191 Scrum立会master:张俊余 一.小组介绍 组长:付佳 组员 ...
- 08慕课网《进击Node.js基础(一)》事件events
引用events模块中的EventEmitter 事件的监听和发射 相同的事件发射数量有限,可以通过setMaxListeners设置峰值 var EventEmitter = require('ev ...
- java实现中值滤波均值滤波拉普拉斯滤波
目录 来对下面的图像滤波,其实就是对各个像素点进行数学运算的过程 均值滤波 中值滤波 拉普拉斯滤波 Sobel滤波 注意 来对下面的图像滤波,其实就是对各个像素点进行数学运算的过程 均值滤波 均值滤波 ...
- 23_IO_第23天(字节流、字符流)_讲义
今日内容介绍 1.字节流 2.字符流 01输入和输出 * A:输入和输出 * a: 参照物 * 到底是输入还是输出,都是以Java程序为参照 * b: Output * 把内存中的数据存储到持久化设备 ...
- java8之重新认识HashMap(转自美团技术团队)
java8之重新认识HashMap 摘要 HashMap是Java程序员使用频率最高的用于映射(键值对)处理的数据类型.随着JDK(JavaDevelopmet Kit)版本的更新,JDK1.8对Ha ...
- sprintf函数 %6.2f
%6.2f6表示数据表示至少6位,后面的.2表示小数点后保留两位 比如2342.123415用这个表示的话,结果就是2342.12如果不足六位就会在前面补空格超过六位的话正常显示 代码例子:int m ...
- HBase 架构与工作原理1 - HBase 的数据模型
本文系转载,如有侵权,请联系我:likui0913@gmail.com 一.应用场景 HBase 与 Google 的 BigTable 极为相似,可以说 HBase 就是根据 BigTable 设计 ...