day python011函数的进阶
形参:
1.位置传参 2. 默认值传参. 3.动态传参
一 动态传参(形参的一种):
之前我们说过了了传参, 如果我们需要给⼀一个函数传参, ⽽而参数⼜又是不确定的. 或者我给⼀一个
函数传很多参数, 我的形参就要写很多, 很⿇麻烦, 怎么办呢. 我们可以考虑使⽤用动态参数.
动态传参分两种:
(1) 动态接收位置参数和默认值参数
def chi(*food):# *表⽰示接收任意内容
print("我要吃", food)
chi("⼤大⽶米饭", "⼩小⽶米饭")
结果:
我要吃 ('⼤大⽶米饭', '⼩小⽶米饭') # 多个参数传递进去. 收到的内容是元组tuple
需要注意的是 : 动态参数必须在位置参数后⾯ 例如:
def chi(*food, a, b):
print("我要吃", food, a, b)
chi("⼤大⽶米饭", "⼩小⽶米饭", "⻩黄⽠瓜", "茄⼦子")
这时程序运⾏行行会报错. 因为前⾯面传递进去的所有位置参数都被*food接收了了. a和b永远接收
不到参数
所以必须改写成以下代码:
def chi(*food, a, b):
print("我要吃", food, a, b)
chi("⼤大⽶米饭", "⼩小⽶米饭", a="⻩黄⽠瓜", b="茄⼦子") # 必须⽤用关键字参数来指定
这个时候a和b就有值了了, 但是这样写呢位置参数就不能⽤用了了. 所以. 我们要先写位置参数,
def chi(a, b, *food):
print("我要吃", a, b, food)
chi("⼤大⽶米饭", "⼩小⽶米饭", "馒头", "⾯面条") # 前两个参数用位置参数来接收, 后⾯面的参数⽤动态参数
动态参数接收
默认值参数
def chi(a, b, c='馒头', *food):
print(a, b, c, food)
chi("⾹香蕉", "菠萝") # ⾹香蕉 菠萝 馒头 (). 默认值⽣生效
chi("⾹香蕉", "菠萝", "葫芦娃") # ⾹香蕉 菠萝 葫芦娃 () 默认值不不⽣生效
chi("⾹香蕉", "菠萝", "葫芦娃", "口罩") # ⾹香蕉 菠萝 葫芦娃 ('口罩',) 默认值不不⽣生效
默认值参数写在动态参数前⾯面. 默认值只有一种情况可能会⽣生效
例子:
def chi(a, b, *food, c="娃哈哈"): #在这里. 其实相当于把传进来的参数做了一次聚合, 聚合成一个元组
print(a, b, food, c)
chi("⾹香蕉", "菠萝") # ⾹香蕉 菠萝 () 娃哈哈 默认值⽣生效
chi("⾹香蕉", "菠萝", "葫芦娃") # ⾹香蕉 菠萝 ('葫芦娃',) 娃哈哈 默认值⽣生效
chi("⾹香蕉", "菠萝", "葫芦娃", "⼝口罩") # ⾹香蕉 菠萝 ('葫芦娃', '⼝口罩') 娃哈哈 默 认值生效
这么写就生效了 这个时候如果不给出关键字传参. 那么你的默
认值是永远都⽣生效的
所以得到结论 :
默认值.位置传参和动态传参的顺序为:位置 动态 默认值参数
(2)关键字传参
在python中使⽤用**来接收动态关键字参数
def func(**kwargs):
print(kwargs)
func(a=, b=, c=)
func(a=, b=)
结果:
{'a': , 'b': , 'c': }
{'a': , 'b': } 这个时候接收的是⼀一个dict
顺序问题
def func(a, b, c, d):
print(a, b, c, d)
# 关键字参数必须在位置参数后⾯面, 否则参数会混乱
func(, , c=, )
所以关键字参数必须在位置参数后⾯面. 由于实参是这个顺序. 所以形参接收的时候也是这
个顺序. 也就是说位置参数必须在关键字参数前⾯面. 动态接收关键字参数也要在后⾯面
综上所述最终结论顺序:
位置参数 > *args > 默认值参数 > **kwargs 这四种参数可以任意的进行使⽤
无敌,模式:
所有的参数都能接收
def func(*args, **kwargs):
# print(args)
# print(kwargs)
#
# func(, , , jj="陶喆", jay="zhoujielun", soup="胡辣汤")
结果为:(1, 2, 5)
{'jj': '陶喆', 'jay': 'zhoujielun', 'soup': '胡辣汤'}
* 和**出现在实参上时
拿个例子来说
def func(*args):
print(args) lst = "娃哈哈"
func(*lst) 结果('娃', '哈', '哈') # 在实参位置 * 表示打散, 打散的是可迭代对象
def func( **kwargs): print(kwargs)
dic = {"": "明教教主", "谢逊": "金毛狮王", "范瑶": "光明右使"}
##func(张无忌=dic['张无忌'], 谢逊=dic['谢逊'], 范瑶=dic['范瑶'])
func(**dic) 结果: {'2': '明教教主', '谢逊': '金毛狮王', '范瑶': '光明右使'}
# 这里的** 是把字典打散. 字典的key作为参数的名字, 字典的值作为参数的值传递给形参
小结:
1. *args 位置参数的动态传参. 系统会自动的把所有的位置参数聚合成元组
# 2. **kwargs 关键字的动态传参. 系统会自动把所有的关键字参数聚合成字典
# 3. def func(*args, **kwargs): 无敌传参
# 4. 顺序: 位置参数, *args, 默认值, **kwargs
# 5. 在使用的时候, 可以任意的进行搭配
# 4. 在实参上. *, **表示的打散. 在形参. *,** 表示聚合
二 命名空间
1.名称空间
内置空间 ::存放python解释器为我们提供的名字, list, tuple, str, int这些都是内置空间
全局空间: :我们直接在py⽂文件中, 函数外声明的变量量都属于全局命名空间
局部空间 : ;在函数中声明的变量量会放在局部命名空间
加载顺序:
1. 内置命名空间
2. 全局命名空间
3. 局部命名空间(函数被执⾏行行的时候)
最开始会开辟一个自己的命名空间- 内置名称空间
a = # 全局
# def func():
# # a = 20# 局部
# print(a)#局部
#
# func()
取值顺序:
局部 => 全局 => 内置
三 作用域(变量或者函数的声明周期)
作⽤用域就是作⽤用范围, 按照⽣生效范围来看分为 全局作⽤用域和局部作⽤用域
全局作⽤用域: 包含内置命名空间和全局命名空间. 在整个⽂文件的任何位置都可以使⽤用(遵循
从上到下逐⾏行行执⾏行行). 局部作⽤用域: 在函数内部可以使⽤用.
全局作用域: 全局名称空间+内置名称空
局部作用域: 局部名称空间
1.我们可以通过globals()函数来查看全局作⽤用域中的内容, 也可以通过locals()来查看局部作
⽤用域中的变量量和函数信息
1. globals() 查看全局作用域中的所有内容
# qiao = "乔峰"
# def 抗收音机():
# bgm = "难念的经"
# print("娃哈哈")
# print(locals())
# 抗收音机() #
print(globals()) ## 查看全局作用域中的内容
print(locals()) # locals()查看的是当前作用域中的内容
四 函数的嵌套
1. 只要遇⻅见了了()就是函数的调用. 如果没有()就不是函数的调⽤
def func1():
# print("我是func1")
#
# def func2():
# print("我是func2")
# func1()
#
# def func3():
# func2()
# print("我是func3")
# func3()
# 这样的代码不是嵌套. 互相调用
2. 函数的执行顺序
简单的嵌套 例子1
ef outer():
# def inner():
# print("我是内部")
# print("我是外部")
# inner()
#
# outer()
例子2
ef outer():
# print("我是外面的")
# def inner_1():
# def inner_2():
# print("我是里面的2")
# inner_2()
# print("我是里面的1")
# inner_1()
# print("我是外面的收尾")
#
# outer()
3.关键字global和nonlocal
首先在全局声明一个变量, 然后再局部调用这个变量, 并改变这
个变量的值
global表示. 不再使用局部作用域中的内容了. 而改用全局作用域中的变量
a =
def func():
global a # 加了了个global表示不再局部创建这个变量了. 而是直接使用全局的a 把全局的变成和局部一样的变量
a =
print(a)
func()
print(a)
a =
# def func():
# global a #表示在当前作用域中的使用的a是全局中的变量
# a = # 所有的a都是外面的了
# print(a) # 现在只有看的权利
#
例子2
lst = ["麻花藤", "刘嘉玲", "詹姆斯"]
def func():
lst.append("⻢马云云") # 对于可变数据类型可以直接进⾏行行访问. 但是不不能改地址. 说⽩白
了了. 不不能赋值
print(lst)
func()
print(lst)
nonlocal(找的是局部当中, 离他最近的上层的那个变量)
def outer():
# a =
# def inner():
# nonlocal a # 找的是局部当中, 离他最近的上层的那个变量
# a =
# print(a)
# print(a) #
# inner() #
# print(a) #
# outer()
global 引入全局变量, 可以定义全局变量
nonlocal 引入局部中离他最近的外层变量
def func():
global a # 没有也得有. 自动帮你创建 # 定义全局变量
a = func()
print(a)
day python011函数的进阶的更多相关文章
- 小学生都能学会的python(函数的进阶)
小学生都能学会的python(函数的进阶) 1. 动态传参 形参: 1. 位置参数 2. 默认值参数 3. 动态传参 *args 动态接收位置参数 **kwargs 动态接收关键字参数 def fun ...
- python基础(9)-迭代器&生成器函数&生成器进阶&推导式
迭代器 可迭代协议和迭代器协议 可迭代协议 只要含有__iter__方法的对象都是可迭代的 迭代器协议 内部含有__next__和__iter__方法的就是迭代器 关系 1.可以被for循环的都是可迭 ...
- 初涉JavaScript模式 (10) : 函数 【进阶用法】
写在前面 不知不觉写到第10篇了.这篇写起来很忐忑,终于和高级搭上边了(呵呵),这篇我们 主要 说一下 JS 方法的部分高级用法(我知道的),笔者水平有限,难免有错.废话不多少,进入正文. 初始化 我 ...
- Python之函数的进阶(带参数的装饰器)
函数篇--装饰器二 带参数的装饰器 def outer(flag): def timer(func): def inner(*args,**kwargs): if flag: print('''执行函 ...
- python成长之路七-函数的进阶
1,python中,名称空间分三种: 全局命名空间 局部命名空间(临时命名空间) 内置名称空间 2,作用域(两种): 1,全局作用域 包含:全局名称空间 内置名称空间 2,局部作用域 包含:局 ...
- day 0314函数的进阶
1.空间:内置空间,全局空间,局部空间. 内置空间:空间存放python解释器,为我们提供了方便的名字:input,print,str,list,tuple 三个空间的加载顺序: 内置空间>&g ...
- python学习 day10打卡 函数的进阶
本节主要内容: 1.函数参数--动态参数 2.名称空间,局部名称空间,全局名称空间,作用域,加载顺序. 3.函数的嵌套 4.gloabal,nonlocal关键字 一.函数参数--动态传参 形参的第三 ...
- 函数的进阶(动态参数,命名空间和作用域,函数的嵌套,gloabal和nonlocal关键字)
1. 函数参数--动态传参 昨天已经解过了传参, 如果需要给一个函数传参,而参数又是不确定的. 或者我们给一个函数传很多参数, 我的形参就要写很多, 写起来就很麻烦, 这时我们可以考虑使用动态参数.形 ...
- python 内置函数(二) 进阶函数 递归内容及二分法查找 知识点
1,lambda: 匿名函数 2.sorgted() 排序函数 3,filter() 过滤函数 筛选 4,map() 映射函数 5.递归 6.二分法 一. 匿名函数: lambda lamb ...
随机推荐
- css 解决fixed 布局下不能滚动的问题
如果我们布局的是后是fixed并且想要高度为100%的时候,我们一般会这样设置: div { display:fixed; height:%; overflow:scroll; } 但是这样并不会出现 ...
- 【SQL】group by 及 having
Group By 分组汇总 HAVING:给分组设置条件 1.概述 “Group By”从字面意义上理解就是根据“By”指定的规则对数据进行分组,所谓的分组就是将一个“数据集”划分成若干个“小区域”, ...
- Win10系列:C#应用控件基础1
Button控件 在Windows应用商店应用的开发中,Button控件是使用比较频繁的控件之一,当用户单击Button控件时,会触发相应的单击事件并在定义好的事件处理方法中执行指定的功能.下面将介绍 ...
- datetime.strptime格式转换报错ValueError
今天遇到一个报错:ValueError: time data '2018-10-10(Wednesday) AM0:50' does not match format '%Y-%m-%d(%A) %p ...
- 通过滑动条控制Cube旋转
private float speed = 10; private float speedValue; private GameObject slider; private GameObject cu ...
- redis:集群配置
一.redis集群相关 1.概念:redis集群是通过数据分区提供可用性的,这样即使一部分节点失效也可以继续处理请求. 2.原理:集群使用数据分片实现,一个redis集群包括16384个哈希槽,数据库 ...
- 二叉排序树,Binary_Sort_Tree,C++完整实现
body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...
- 第三篇 功能实现(3) (Android学习笔记)
第三篇 功能实现(3) ●发一个广播和启动一个隐式的Intent非常像,那么它们之间有什么区别呢? Implicit Intents (sent via startActivity( )) and B ...
- Centos7安装配置iptable
CentOS7默认的防火墙不是iptables,而是firewalle. 安装iptable iptable-service #先检查是否安装了iptables service iptables st ...
- DevExpress WPF v18.2新版亮点(二)
买 DevExpress Universal Subscription 免费赠 万元汉化资源包1套! 限量15套!先到先得,送完即止!立即抢购>> 行业领先的.NET界面控件2018年第 ...