day10 十 函数、形参和实参
一、形参和实参
1、形参:在函数定义()中出现的参数形参就是拷贝实参的值,随着函数的调用才产生,随着函数调用结束而销毁
def fn(a, b, c):
print(a)
print(b)
print(c)
print(x)
print(y)
print(z) x = 100
y = 1000
z = 10000 # x, y ,z 是外界实际存在的值
2、实参:在函数调用()中出现的参数(外界实际存在的值)
调用函数时,实参可以有常量,变量,表达式或三种组合。
在函数的外部不能直接使用函数的形参,原因:函数调用完毕后,形参被销毁了
fn(10, 20, 30)
fn(x, y, z)
fn(x + 10, y * 2, z / 5)
二、实参的分类
1、位置实参:不用明确形参名的传参方式,一定按照位置给形参传值
def fn1(a, b, c):
print(a, b, c) fn1(10, 20, 30) # 必须按照顺序
2、关键字实参:必须明确形参名与值为形参传值,可以不用按照位置
def fn1(a, b, c):
print(a, b, c) fn1(a=10, b=20, c=30)
fn1(c=30, b=20, a=10) # 可以不用按照顺序
3、位置实参和关键字实参两者混用:
关键字实参必须出现在位置实参后
多个位置实参还是按照位置传参
关键字实参为没有从位置实参拿到值的形参传值,可以不用按照指定顺序
def fn2(a, b, c, d, e, f):
print(a, b, c, d, e, f) fn2(10, 20, 30, e=100, f=500, d=200) # 结果为 10 20 30 200 100 500 fn1(10, c=20, a=30) # 10按位置传参给a,a=30给a传参,c可以拿到20,但b没人传参
# TypeError:fn1() got multiple values for argument 'a' a被多次传值
三、位置形参的范畴
1、位置形参:可以由‘位置实参’与‘关键字实参’来传值
def fn(a, b, c):
print(a, b, c) fn(10, 20, 30) # 结果为10 20 30
fn(a=10, b=20, c=30) # 结果为10 20 30
2、默认形参:可以由‘位置实参’与‘关键字实参’来传值,还可以不用传值(采用自身默认值)
def fn(a=10, b=20,):
print(a, b,) fn(20, 30) # 位置实参
fn(a=200, b=300) # 关键字实参
fn(100) # 没传值
fn(b=100) # 位置形参与默认形参同时存在,默认形参必须在后
def fn(a, b, d=1000, c=5000):
print(a, b, c, d)
fn(100, 200, d=1000) # 位置形参必须传值,默认形参分情况传值 # 结果为 100 200 5000 1000
3、可变长位置形参:只能由’位置实参’来传值(*****)
可变长形参会以元组形式接收,位置形参与默认形参没有接收完的,所有传入的位置实参,用索引来取第几个
def fn(a, b=500, *args):
print(a, b)
print(args)
fn(1, 20, 100, 200)
# 结果为
1 20
(100, 200) fn(100)
# 结果为
100 500
()
4、可变长形参的整体赋值:
def fn(*args):
print(args)
fn(1, 2, 3, 4, 5) # 结果为 (1, 2, 3, 4, 5) a = 'ab'
b = [1, 2]
c = (1, 2)
d = {1, 2}
fn(a) # 结果为 ('ab', )
fn(b) # 结果为 ([1, 2], )
fn(c) # 结果为 ((1, 2), )
fn(d) # 结果为 ({1, 2}, )
# 问就拿a,b,c,d进行传值,如何得到
# ('a', 'b')
# (1, 2) # 解答:通过 打散传值(本质传递的是地址)
fn(*a) # 结果为 ('a', 'b')
fn(*b) # 结果为 (1, 2)
fn(*c) # 结果为 (1, 2)
fn(*d) # 结果为 (1, 2) # 打散传值
def fn(*args):
print(args)
ls = [1, 2, 3, 4, 5]
fn(ls) # 结果为 ([1, 2, 3, 4, 5],)
fn(*ls) # 结果为 (1,2,3,4,5) # 将ls打散为1,2,3,4,5再进行传值
四、关键字形参的范畴
1、关键字形参:必须由 '关键字实参'来传值, 出现在*后的都是关键字形参(*****)
前提:出现在 * 之后的形参 。*为分割线,可以有变量名 *args, 也可以只用来做分隔
def fn(a, b=10, *, c, d=20, e):
pass a 位置形参
b 默认形参
c,e 无值关键字形参
d 有值关键值形参
注意:a和b有先后顺序,c,d,e无先后顺序
c,d,e都是出现在*之后,都是关键字形参,
由于必须由 关键字实参 来传值,没有顺序的强行要求
def tt(a, b=10, *, c, d=10, e):
print(a, b, c, d, e) def fn(*, a, b=10, c):
print(a, b, c)
fn(b=300, c=100, a=200) # 结果为 200 300 100 # 没有顺序的强行要求
2、可变长关键字形参:用来接收没有被‘关键字形参’接收完的关键字形参,也只能由关键字实参来传值
用字典来存放数据{}
def fn(*, a, b=20, c, **kwargs):
print(a, b)
print(kwargs)
fn(d=40, e=50, a=10, c=30)
# 结果为
10 20
{'d': 40, 'e': 50}
3、可变长关键字形参的整体赋值:
dic = {'name': 'Owen', 'age': 18}
def fn1(**kwargs):
print(kwargs)
fn1(**dic) # 结果为 {'name': 'Owen', 'age': 18}
dd = {'k1': [1, 2, 3, 4, 5], 'k2': {"name":"Bob"}}
fn1(**dd) # 结果为 {'k1': [1, 2, 3, 4, 5], 'k2': {'name': 'Bob'}}
def fn2(*args):
print(args)
ll = [1, [1, 2], {"name":"Bob"}]
fn2(*ll) # 结果为 (1, [1, 2], {"name":"Bob"})
五、参数总结
1、位置形参与默认形参: 能用 位置实参 关键字实参 传值
2、可变长位置形参:只能 位置实参 传值
3、所以关键字形参:只能 关键字实参 传值
def fn(a, b=10, *args, d, f=20, **kwargs):
print(a)
print(b)
print(args)
print(d)
print(f)
print(kwargs) 有位置实参传值: args和kwargs如果都能接收到值:
b必须传值且只能用位置实参传值,f可以不用传值
fn(1,2,3,4,d=5,g=6,k=7)
print()
# 结果为
12
(3, 4)
520
{'g': 6, 'k': 7} 全部用关键字实参传值
fn(x=100, y=200, d=300, b=400, a=500)
# 结果为
500400
()
30020
{'x': 100, 'y': 200}
day10 十 函数、形参和实参的更多相关文章
- 【学习笔记】--- 老男孩学Python,day10, 初识函数 形参、实参
函数:对功能的封装语法: def 函数名(形参): 函数体 函数名(实参) 函数名:命名规则和变量一样 函数的返回值: return, 函数执行完毕. 不会执行后面逻辑 1. 如果函数中不写retur ...
- c++之函数形参和实参
c++之函数形参和实参讲解 1.非地址型参数 在c++中实现模块化编程时,我们形成会遇到对自定义的函数模块传入参数的操作,即形参.这里主要讲解一个非地址型的形参. 不多说,先看代码: #include ...
- python之函数形参、实参、可变长参数整体使用和分类
形参与实参 '''def fn(形参们): pass fn(实参们)'''# 形参:定义函数,在括号内声明的变量名,用来结束外界传来的值# 实参:调用函数,在括号内传入的实际值,值可以为常量.变量.表 ...
- python函数—形参、实参、位置参数、关键字参数
1.通过def function_name([parameter]): 定义,函数一遇到return即结束运行.如果函数没有定义返回值,则返回None,如果定义了一个返回值,则返回该对象,如果一个re ...
- js函数形参和实参的区别
在<Javascript权威指南>中这样定义: 参数有形参(parameter)和实参(argument)的区别,形参相当于函数中定义的变量,实参是在运行时的函数调用时传入的参数. 说明白 ...
- C++函数形参与实参交换
c++中函数的实参传递到形参的值是单向的,改变形参并不会影响实参. #include <iostream> using namespace std; void swap(int a, in ...
- JavaScript中函数的形参和实参的实现原理剖析
我们都知道JS里面参数的传递是可以不一样的,比如我们有一个函数: <script type="text/javascript"> function one(a,b,c) ...
- javascript . 03 函数定义、函数参数(形参、实参)、函数的返回值、冒泡函数、函数的加载、局部变量与全局变量、隐式全局变量、JS预解析、是否是质数、斐波那契数列
1.1 知识点 函数:就是可以重复执行的代码块 2. 组成:参数,功能,返回值 为什么要用函数,因为一部分代码使用次数会很多,所以封装起来, 需要的时候调用 函数不调用,自己不会执行 同名函数会覆盖 ...
- Pyhton函数篇(一)之函数中的形参与实参
1:什么是函数 函数其实就是带名字的代码块,用于完成一些具体的工作.如果我们在写一段程序的时候,需要多次用到同样的一个功能,如果每次都要重复写相同的代码,不仅会增加我们的代码量,更会让我们写出的代码让 ...
随机推荐
- 问题解决java.lang.IllegalArgumentException at org.springframework.asm.ClassReader
手上拿到一个老的项目,使用的是spring3.2,启动的时候报错了: 查了一下,发现spring3.2不兼容jdk8,只能使用jdk8以下的版本,使用jdk6可以启动,但是maven构建的时候又提示不 ...
- ELK菜鸟手记 (一) 环境配置+log4j日志记录
1. 背景介绍 在大数据时代,日志记录和管理变得尤为重要. 以往的文件记录日志的形式,既查询起来又不方便,又造成日志在服务器上分散存储,管理起来相当麻烦, 想根据一个关键字查询日志中某个关键信息相当困 ...
- python3用BeautifulSoup用字典的方法抓取a标签内的数据
# -*- coding:utf-8 -*- #python 2.7 #XiaoDeng #http://tieba.baidu.com/p/2460150866 #标签操作 from bs4 imp ...
- maven本地仓库中存在jar包,但编译不成功,显示jar包不存在
介绍一下背景,项目要迁移进坑人的离线的内网开发,将在同事那编译通过的代码和maven仓库拷进内网,打算编译通过之后再上传私服,结果配好maven之后,本地库中的部分jar包显示没有引入,如下面的波浪线 ...
- 【SqlServer】解析SqlServer中的事务
目录结构: contents structure [+] 事务是什么 控制事务 数据并发访问产生的影响 事务的隔离级别 锁 NOLOCK.HOLDLOCK.UPDLOCK 死锁分析 在这篇Blog中, ...
- Java 8 – MinguoDate examples
1. LocalDate -> MinguoDate Review a full example to convert a LocalDate to MinguoDate TestMinguoD ...
- 【Tomcat】Servlet 工作原理解析
Web 技术成为当今主流的互联网 Web 应用技术之一,而 Servlet 是 Java Web 技术的核心基础.因而掌握 Servlet 的工作原理是成为一名合格的 Java Web 技术开发人员的 ...
- python os详解
1.os.getcwd()--起始执行目录 获取当前执行程序文件所在的目录,需要注意的是,getcwd不是获取代码所在文件的目录,也不是获取执行文件所在的目录,而是起始执行目录. 目录结构: test ...
- 【转】python实战——教你用微信每天给女朋友说晚安
但凡一件事,稍微有些重复.我就考虑怎么样用程序来实现它. 这里给各位程序员朋友分享如何每天给朋友定时微信发送”晚安“,故事,新闻,等等··· ··· 最好运行在服务器上,这样后台挂起来更方便. #!/ ...
- pycharm如何在debug的时候动态执行python语句
在调试MATLAB的时候,这一点很容易实现,比如动态修改变量的值,在VS2017中调试python程序,这一点也很容易实现,但是我在pycharm里面找了半天,如下图: