一、形参和实参

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 十 函数、形参和实参的更多相关文章

  1. 【学习笔记】--- 老男孩学Python,day10, 初识函数 形参、实参

    函数:对功能的封装语法: def 函数名(形参): 函数体 函数名(实参) 函数名:命名规则和变量一样 函数的返回值: return, 函数执行完毕. 不会执行后面逻辑 1. 如果函数中不写retur ...

  2. c++之函数形参和实参

    c++之函数形参和实参讲解 1.非地址型参数 在c++中实现模块化编程时,我们形成会遇到对自定义的函数模块传入参数的操作,即形参.这里主要讲解一个非地址型的形参. 不多说,先看代码: #include ...

  3. python之函数形参、实参、可变长参数整体使用和分类

    形参与实参 '''def fn(形参们): pass fn(实参们)'''# 形参:定义函数,在括号内声明的变量名,用来结束外界传来的值# 实参:调用函数,在括号内传入的实际值,值可以为常量.变量.表 ...

  4. python函数—形参、实参、位置参数、关键字参数

    1.通过def function_name([parameter]): 定义,函数一遇到return即结束运行.如果函数没有定义返回值,则返回None,如果定义了一个返回值,则返回该对象,如果一个re ...

  5. js函数形参和实参的区别

    在<Javascript权威指南>中这样定义: 参数有形参(parameter)和实参(argument)的区别,形参相当于函数中定义的变量,实参是在运行时的函数调用时传入的参数. 说明白 ...

  6. C++函数形参与实参交换

    c++中函数的实参传递到形参的值是单向的,改变形参并不会影响实参. #include <iostream> using namespace std; void swap(int a, in ...

  7. JavaScript中函数的形参和实参的实现原理剖析

    我们都知道JS里面参数的传递是可以不一样的,比如我们有一个函数: <script type="text/javascript"> function one(a,b,c) ...

  8. javascript . 03 函数定义、函数参数(形参、实参)、函数的返回值、冒泡函数、函数的加载、局部变量与全局变量、隐式全局变量、JS预解析、是否是质数、斐波那契数列

    1.1 知识点 函数:就是可以重复执行的代码块 2.  组成:参数,功能,返回值 为什么要用函数,因为一部分代码使用次数会很多,所以封装起来, 需要的时候调用 函数不调用,自己不会执行 同名函数会覆盖 ...

  9. Pyhton函数篇(一)之函数中的形参与实参

    1:什么是函数 函数其实就是带名字的代码块,用于完成一些具体的工作.如果我们在写一段程序的时候,需要多次用到同样的一个功能,如果每次都要重复写相同的代码,不仅会增加我们的代码量,更会让我们写出的代码让 ...

随机推荐

  1. VMWare虚拟机中CPU过高的问题

    在VMWare中按默认方式创建的虚拟机,安装的Windows Server 2016 x64操作系统.可打开一个稍微大一点的程序CPU就飙到90%以上,自然整个系统操作起来很卡. 在VMWare中看到 ...

  2. 微软BI 之SSIS 系列 - 通过 OLE DB 连接访问 Excel 2013 以及对不同 Sheet 页的数据处理

    文章更新历史 2014年9月7日 - 加入了部分更新内容,在文章最后提到了关于不同 Office Excel 版本间的连接问题. 开篇介绍 这篇文章主要总结在 SSIS 中访问和处理 Excel 数据 ...

  3. 搞定所有的跨域请求问题 jsonp CORS

    网上各种跨域教程,各种实践,各种问答,除了简单的 jsonp 以外,很多说 CORS 的都是行不通的,老是缺那么一两个关键的配置.本文只想解决问题,所有的代码经过亲自实践.   本文解决跨域中的 ge ...

  4. 开源配置管理平台-Apollo

    Apollo(阿波罗)是携程框架部门研发的配置管理平台,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推送到应用端. Apollo官网地址

  5. Instrumentation 功能介绍(javaagent)

    利用 Java 代码,即 java.lang.instrument 做动态 Instrumentation 是 Java SE 5 的新特性,它把 Java 的 instrument 功能从本地代码中 ...

  6. 每日英语:The Right Way to Network

    With startup-themed conferences, hackathons, meet-ups and cocktail hours regularly taking place, ent ...

  7. linux每日命令(5):mkdir命令

    linux mkdir 命令用来创建指定的名称的目录,要求创建目录的用户在当前目录中具有写权限,并且指定的目录名不能是当前目录中已有的目录. 1.命令格式: mkdir [选项] 目录名或路径名 2. ...

  8. JS中的Map和Set实现映射对象

    使用iterable内置的forEach方法 var a = ['A', 'B', 'C']; a.forEach(function (element, index, array) { // elem ...

  9. Android开发(十五)——ListView中Items的间距margin

    ListView中Items没有margin 参考:http://www.cnblogs.com/xitang/p/3677528.html

  10. [转]css实现左侧宽度自适应,右侧固定宽度

    原文地址:https://segmentfault.com/a/1190000008411418 页面布局中经常用会遇到左侧宽度自适应,右侧固定宽度,或者左侧宽度固定,右侧自适应.总之就是一边固定宽度 ...