python基础—函数参数
时间:2022-07-22
本文章向大家介绍python基础—函数参数,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
基本定义
- def 语句定义函数
def 函数名(参数列表):
函数体(代码块)
return 返回值
- 函数名就是标识符
- 语句块必须缩进
- 可以没有return语句,如果没有默认返回None值
- 定义中的参数列表成为形式参数,只是一种符号表达,简称形参
调用
- 函数定义,只是声明了一个函数,它不会被执行,需要调用
- 调用的方式,就是函数名加上小括号,括号内加上参数
- 调用时写的参数是实际参数,是实实在在传入的值,简称实参
函数参数
- 参数调用时传入的参数要和定义的个数相匹配(可变参数例外)
- 位置参数
- def f(x,y,z) 调用时使用f(1,3,5)
- 按照参数定义顺序传入实参
- 关键字参数
- def f(x,y,z) 调用使用f(x=1,y=3,z=5)
- 使用形参的名字来出入实参的方式,如果使用了形参名字,那么传参顺序就可以和定义顺序不同
- 传参
- f(z=None, y=10, x=[1])
- f((1,), z=6, y=4.1)
- 位置参数必须在关键字参数之前传入,位置参数是按位置对应的
- 默认参数
- 定义时,在形参后跟上一个值
def add(x=4, y=5):
return x+y
- 作用
- 参数的默认值可以在未传入足够的实参的时候,对没有给定的参数赋值为默认值
- 参数非常多的时候,并不需要用户每次都输入所有的参数,简化函数调用
- 可变参数
- 一个形参可以匹配任意个参数
- 位置参数的可变参数
- 例如:有多个数,需要累加求和
- 位置参数的可变参数
- 一个形参可以匹配任意个参数
在形参前使用 * 表示该形参是可变参数,可以接收多个实参
</li>
<li>
收集多个实参为一个tuple
</li>
- 关键字参数的可变参数
- 配置信息打印
形参前使用 ** 符号,表示可以接收多个关键字参数
</li>
<li>
收集的实参名称和值组成一个字典
</li>
- 可变参数的混合使用
- 配置信息打印
注意: 最后一个参数的顺序是错误的,因为可变的位置参数,是不能放在关键字参数后面的,否则会出错。
- keyword-only参数
- 如果在一个星号参数后,或者一个位置可变参数后,出现的普通参数,实际上已经不是普通的参数了,而是Keyword-only参数
- args参数已经截获了所有的位置参数,x不适用关键字参数就不可能拿到实参,所以如果避免出错,x必须以关键字的形式传参,例如:fn(1,2,3,4,5,x=1)
注意: keyword-only也可以写成另一种形式 def fn(*,x,y),直接写一个星号 * 普通形参都变成了必须给出的keyword-only参数了
总结
- 有位置可变参数和关键字可变参数
- 位置可变参数在形参前使用一个星号 *
- 关键字参数在形参前使用两个星号 **
- 位置可变参数和关键字可变参数都可以收集若干个实参,位置可变参数收集形成一个tuple,关键字可变参数收集形成一个dict
- 混合使用参数的时候,可变参数要放到参数列表的最后,普通参数需要放到参数列表前面,位置可变参数需要在关键字可变参数之前
参数示例
1、不能重复传参
出错的原因是: x已经传过参了,后面又出现了一次,所以错误
2、可变参数和参数默认值
这个函数,我们首先必须要输入一个位置参数y,第一个func()肯定是错误的,第三个也是错误的
第五个位置参数不能放在关键字参数后面,所以也会报错
最后一个重复传参,所以也是错误的
根据上面的示例,我们知道了函数参数的一些规则和注意事项,所以,参数是有一定的顺序的:
- 参数顺序:普通参数,默认参数,可变位置参数,keyword-only参数,可变关键字参数
注意: keyword-only参数一定要作为实参传进去,否则会报错。
- TensorFlow模拟简单线性模型小栗子
- web跨域解决方案
- Bootstrap幻灯轮播如何支持触屏左右滑动手势?
- JavaScript 调试小技巧
- 图片上传预览js
- Isolation Forest算法实现详解
- css继承样式怎么控制?用选择器
- wordpress站内搜索结果页URL伪静态如何操作
- 如何实现大图居中超过的部分两边自动隐藏
- Ubuntu16.04安装后开发环境配置和常用软件安装
- wordpress如何屏蔽wp-json(禁用REST API)
- 贝叶斯系列——贝叶斯与其他统计流派的区别和联系
- bootstrap tab切换如何让鼠标移动自动切换内容
- css自动换行如何设置?url太长会撑开页面
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Linux实现文件内容去重及求交并差集
- Linux rpm、yum指令及使用方法详解
- Linux下遇到PyCurl的错误解决方法
- Linux cut 命令详解
- linux下安装ffmpeg的详细教程
- 如何利用Gitlab-ci持续部署到远程机器(详细教程)
- Linux常用命令之grep命令用法详解
- 详解Linux动态库生成与使用指南
- Vue 3 入门基础知识
- 在Linux系统中使用Vim读写远程文件的命令详解
- Vue.js实现咸鱼底部Tab凸起|vue自定义导航条组件
- 在Linux中查看所有正在运行的进程的方法
- Apache跨域资源访问报错问题解决方案
- Windows Telemetry服务特权提升
- 滥用DComposition在外部窗口上渲染