Python函数的参数常见分类与用法实例详解

本文实例讲述了Python函数的参数常见分类与用法。分享给大家供大家参考,具体如下:

1.形参与实参是什么?

形参(形式参数):指的是

在定义函数时,括号内定义的参数,形参其实就是变量名

实参(实际参数):括号内传入的值,实参其实就是变量的值

x,y是形参

def func(x,y):
  print(x)
  print(y)
func(20,30)
#20,30是实参

注意:实参值(变量的值)与形参(变量名)的绑定关系只在函数调用时才会生效/绑定在函数调用结束后就立刻解除绑定。

2.函数的参数

位置即顺序,位置参数参数指的就是按照从左到右的顺序依次定义的参数。

3.有两种参数:

(1)在定义时,按照位置定义的形参,称为位置形参

def foo(x,y,z):
  print(x,y,z)
foo(1,2,3)

注意:位置形参的特性是:在调用函数时必须为其传值,而且多一个不行,少一个也不行。

(2)在调用函数时,按照位置定义的实参,称为位置实参。

注意:位置实参会与形参一一对应。

4.什么是关键字参数:

在调用函数时,按照key=value的形式定义的实参,称为关键字参数。

def foo(x,y,z):
  print(x,y,z)
foo(5,9,3)
foo(y=8,x=1,z=4)

注意:相当于指名道姓的为形参传值,意味着即便不是按照顺序定义,仍然能为指定的参数传达值。

(1)在调用函数时,位置实参与关键字实参可以混合使用,但必须遵循形参的规则。

def foo(x,y,z):
  print(x,y,z)
foo(1,z=3,y=2) #这样写是正确的
foo(1,z=5) #这个没有遵循实参的规则,所以会报错

(2)不能为同一个形参重复传值。

(3)位置实参必须放到关键字实参的面前。

def foo(x,y,z):
  print(x,y,z)
foo(x=8,y=7,3) #里面的3就是位置实参,放在后面和中间都是不行的,必须要放在关键字实参的前面

这样才是正确的用法:

def foo(x,y,z):
  print(x,y,z)
foo(3,y=7,z=8)

5.默认参数

在定义阶段,已经为某个形参赋值,那么该形参就称为默认参数

注意:

(1)定义阶段已经有值,意味着调用阶段可以不传值。

def register(name,pasd,sex='yuan'):
  print(name,pasd,sex)
register('liuyuan',22,)
register('xiang',22)
register('xxx',80)

(2)位置形参必须在默认参数的面前

def func(y=1,x): #这是错误的,里面的x为位置形参,不能放在后面。
  pass

(3)默认参数的值只在定义的阶段赋值一次,也就是说默认参数的值再定义就固定死了。

s=88
def foo(x,y=s):
  print(x,y)
s='555555555555555'
foo(1)
foo(1,22)

输出结果:

1 88
1 22

(4)记住:默认参数的值应该设置为不可变类型

def register(name,hobby,l=None):
  if l is None:
    l=[]
  l.append(hobby)
  print(name,l)
register('liuyuan','play')
register('xiang','read')

以上输出:

liuyuan ['play']
xiang ['read']

应用:对于经常需要变化的值,需要将对应的形参定义成位置形参

对于大多数情况值都一样的情况,需要将对应的形参定义成默认形参

6.可处理以上两种形式变参数

什么是可变参数?

可变长度指的参数的个数可以不固定,实参有按位置定义的实参和按关键字定义的实参,

所以可变长的实参指的就是按照这两种形式定义的实参个数可以不固定。

然而实参终究是要给形参传值的

所以形参必须有两种对应解决方案来分别处理以上两种形式可变长度的实参。

(1)形参里面包含*与**

*会将溢出的位置实参全部接收,然后保存成元组的形式赋值给args

def foo(x,y,z,*args):
  print(x,y,z)
  print(args)
foo(1,2,3,4,5,6,7,8,)

以上输出:

1 2 3
(4, 5, 6, 7, 8)

**会将溢出的关键字实参全部接收,然后保存成字典的形式赋值给kwargs

def foo(x,y,z,**kwargs):
  print(x,y,z)
  print(kwargs)
foo(x=1,y=2,z=3,a=5,b=6,c=7)

以上输出:

1 2 3
{'a': 5, 'b': 6, 'c': 7}

注意:实参里面包含*与**

一旦碰到实参加*,就把该实参的值打散

def foo(x,y,z,*args):
  print(x,y,z)
  print(args)
foo(1,2,3,*[4,5,6,7,8,9])
foo(1,2,3,*'h,e,l,l,o')

以上输出:

1 2 3
(4, 5, 6, 7, 8, 9)
1 2 3
('h', ',', 'e', ',', 'l', ',', 'l', ',', 'o')

一旦碰到实参加**,就该把该实参的值打散。

def foo(x,y,z,**kwargs):
  print(x,y,z)
  print(kwargs)

以上输出:

1 8 3
{}

重点:组合使用

这种方法我们以后肯定会经常用到的。

def index(name,age,gender):
  print('welcome %s %s %s' %(name,age,gender))
def wrapper(*args,**kwargs): #args=(1,2,3),kwargs={'x':1,'y':2,'z':3}
  index(*args,**kwargs) # index(*(1,2,3),**{'x':1,'y':2,'z':3}) # index(1,2,3,z=3,y=2,x=2)
wrapper('egon',age=18,gender='male')
wrapper('egon',18,gender='male')
wrapper('egon',18,'male')

以上输出:

welcome yuan 18 male
welcome xiang 18 male
welcome abasida 0.6 male

关于Python相关内容感兴趣的读者可查看本站专题:《Python函数使用技巧总结》、《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

(0)

相关推荐

  • 详解python的argpare和click模块小结

    一.argparse模块 1.模块说明 # argparse是python的标准库中用来解析命令行参数的模块,用来替代已经过时的optparse模块,argparse能够根据程序中的定义的sys.argv中解析出这些参数, # 并自动生成帮助和使用信息 2.模块常用的参数 # 参数说明: # name/flag:参数的名字 # action:遇到参数的动作,默认值是store # nargs:参数的个数,可以是具体的数字,或者是+或者是*,*表示0个或者多个参数,+号表示1个或者多个参数 # d

  • Python文件打开方式实例详解【a、a+、r+、w+区别】

    本文实例讲述了Python文件打开方式.分享给大家供大家参考,具体如下: 第一步 排除文件打开方式错误: r只读,r+读写,不创建 w新建只写,w+新建读写,二者都会将文件内容清零 (以w方式打开,不能读出.w+可读写) w+与r+区别: r+:可读可写,若文件不存在,报错:w+: 可读可写,若文件不存在,创建 r+与a+区别: fd = open("1.txt",'w+') fd.write('123') fd = open("1.txt",'r+') fd.wr

  • Python实现定时执行任务的三种方式简单示例

    本文实例讲述了Python实现定时执行任务的三种方式.分享给大家供大家参考,具体如下: 1.定时任务代码 #!/user/bin/env python # @Time :2018/6/7 16:31 # @Author :PGIDYSQ #@File :PerformTaskTimer.py #定时执行任务命令 import time,os,sched schedule = sched.scheduler(time.time,time.sleep) def perform_command(cmd

  • 详解Python解决抓取内容乱码问题(decode和encode解码)

    一.乱码问题描述 经常在爬虫或者一些操作的时候,经常会出现中文乱码等问题,如下 原因是源网页编码和爬取下来后的编码格式不一致  二.利用encode与decode解决乱码问题 字符串在Python内部的表示是unicode编码,在做编码转换时,通常需要以unicode作为中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码. decode的作用是将其他编码的字符串转换成unicode编码,如str1.decode('gb2312

  • Python函数装饰器常见使用方法实例详解

    本文实例讲述了Python函数装饰器常见使用方法.分享给大家供大家参考,具体如下: 一.装饰器 首先,我们要了解到什么是开放封闭式原则? 软件一旦上线后,对修改源代码是封闭的,对功能的扩张是开放的,所以我们应该遵循开放封闭的原则. 也就是说:我们必须找到一种解决方案,能够在不修改一个功能源代码以及调用方式的前提下,为其加上新功能. 总结:原则如下: 1.不修改源代码 2.不修改调用方式 目的:在遵循1和2原则的基础上扩展新功能. 二.什么是装饰器? 器:指的是工具, 装饰:指的是为被装饰对象添加

  • Python datetime和unix时间戳之间相互转换的讲解

    python datetime和unix时间戳之间相互转换 1.代码: import time import datetime # 1.datetime转unix时间戳 # (1).逐个打印 n = datetime.datetime.now() #当前时间 a = n.timetuple() b = time.mktime(a) c = int(b) # (2).链式打印 r = int(time.mktime(datetime.datetime.now().timetuple())) # 2

  • Python实现的爬取小说爬虫功能示例

    本文实例讲述了Python实现的爬取小说爬虫功能.分享给大家供大家参考,具体如下: 想把顶点小说网上的一篇持续更新的小说下下来,就写了一个简单的爬虫,可以爬取爬取各个章节的内容,保存到txt文档中,支持持续更新保存.需要配置一些信息,设置文档保存路径,书名等.写着玩,可能不大规范. # coding=utf-8 import requests from lxml import etree from urllib.parse import urljoin import re import os #

  • Python提取特定时间段内数据的方法实例

    python提取特定时间段内的数据 尝试一下: data['Date'] = pd.to_datetime(data['Date']) data = data[(data['Date'] >=pd.to_datetime('20120701')) & (data['Date'] <= pd.to_datetime('20120831'))] 实际测试 ''' Created on 2019年1月3日 @author: hcl ''' import pandas as pd import

  • Python函数基础实例详解【函数嵌套,命名空间,函数对象,闭包函数等】

    本文实例讲述了Python函数基础用法.分享给大家供大家参考,具体如下: 一.什么是命名关键字参数? 格式: 在*后面参数都是命名关键字参数. 特点: 1.约束函数的调用者必须按照Kye=value的形式传值. 2.约束函数的调用者必须用我们指定的Key名. def auth(*args,name,pwd): print(name,pwd) auth(pwd='213',name='egon') def register(name,age): print(type(name),type(age)

  • linux安装python修改默认python版本方法

    linux默认是安装了python,默认是安装python2.6.6,可能安装的版本是不能符合我们需要的python要求的.我们需要重新安装python的版本,今天演示一下安装python3 首先下载一个  wget  文件的地址  执行命令进行下载 下载完成以后进行解压,解压完成以后进行安装,执行tar -zxvf Python-3.6.1.tgz解压 cd Python-3.6.1 进入目录 ./configure --prefix=/usr/local/python3  配置python安

随机推荐