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:什么是函数 函数其实就是带名字的代码块,用于完成一些具体的工作.如果我们在写一段程序的时候,需要多次用到同样的一个功能,如果每次都要重复写相同的代码,不仅会增加我们的代码量,更会让我们写出的代码让 ...
随机推荐
- Spark机器学习(4):朴素贝叶斯算法
1. 贝叶斯定理 条件概率公式: 这个公式非常简单,就是计算在B发生的情况下,A发生的概率.但是很多时候,我们很容易知道P(A|B),需要计算的是P(B|A),这时就要用到贝叶斯定理: 2. 朴素贝叶 ...
- JAVA四则运算字符串解释器
最近学习到后缀表达式,于是基于后缀表达式的思想,写了一个四则运算解释器,输入字符串类型的四则运算表达式,可以直接得到结果,支持括号嵌套. 实现时主要考虑以下两点: 字符串中运算符和数字分离 运算符优先 ...
- ASP.NET MVC ViewBag/ViewData/TempData区别
ViewBag/ViewData public dynamic ViewBag { get; } public ViewDataDictionary ViewData { get; set; } Vi ...
- maven本地仓库中存在jar包,但编译不成功,显示jar包不存在
介绍一下背景,项目要迁移进坑人的离线的内网开发,将在同事那编译通过的代码和maven仓库拷进内网,打算编译通过之后再上传私服,结果配好maven之后,本地库中的部分jar包显示没有引入,如下面的波浪线 ...
- 12C新特性--Application Continuity
Application Continuity特性可以在中断后恢复受影响的数据库会话的任务,从而让终端用户和应用程序感觉不到中断的发生.Application Continuity执行恢复的过程是在应用 ...
- jQuery Address全站 AJAX 完整案例详解
本文详细介绍如何利用 jQuery 框架以及 jQuery Address 插件实现最基本的全站 AJAX 动态加载页面内容的功能的方法. 案例目标 以常见基本结构的网站为案例,实现全站链接 AJAX ...
- Chrome 调试技巧: 调整网速
为了方便调试某些内容,比如我想网速设置为 1kb每秒,甚至0kb每秒. 1.打开chrome DevTool ,切换到 "Network".找到最右侧 "Online&q ...
- 清除win下连接的linux的samba服务缓存 用户名和密码
1:cmd 2:在停止查看共享的情况下执行:net use * /del 删除所有 或根据列表,一个个删除连接: net use 远程连接名称 /del
- 初识HTTPS
初识HTTPS HTTPS也被叫做“基于TLS的HTTP,基于SSL的HTTP,HTTP安全“,它是一个在Internet上广泛使用的计算机网络安全通信协议. 即HTTPS是HTTP的安全版本,在了解 ...
- python 函数的参数的几种类型
定义函数的时候,我们把参数的名字和位置确定下来,函数的接口定义就完成了.对于函数的调用者来说,只需要知道如何传递正确的参数,以及函数将返回什么样的值就够了,函数内部的复杂逻辑被封装起来,调用者无需了解 ...