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 ...
随机推荐
- 微信小程序 HMACSHA256 哈希加密
下载CryptoJS, 增加红色的这句 module.exports = CryptoJS /* CryptoJS code.google.com/p/crypto-js (c) 2009-2012 ...
- Net Core2.0 升级到.Net Core 2.1
1. 安装新 .Net Core SDK 2.1 2. 升级VS.net 到15.7, 这个版本极其不好用,IIS打中文会自动退出,但现在也没办法降级了.只能等微软打补丁. 3. 对于面向 ASP.N ...
- vue 中使用 Toast弹框
import { ToastPlugin,ConfirmPlugin,AlertPlugin} from 'vux' Vue.use(ToastPlugin) Vue.use(ConfirmPlugi ...
- CAD绘制室外平台步骤5.3
1.在平面上用直线划出台阶范围. “工具”“曲线工具”“线变复线”选择这几条线,它们就变成了一条线. “三维建模”“造型对象”“平板”选择这条封闭的线,回车,选择相邻门窗柱子等,回车输入平台厚度如“- ...
- 如何破解Visual studio 2013
1.打开VS2013点击菜单栏中的帮助,选择注册产品. 2.如下图所示,你就可以看到你的VS是不是试用版了,很显然,现在我的还是试用版,还有20天的使用期限. 3.如下图所示,点击更改我的产品许可证. ...
- tomcat原理详解
tomcat的启动是通过Bootstrap类的main方法(tomcat6开始也可以直接通过Catlina的main启动) Bootstrap的启动 Bootstrap的main方法先new了一个自己 ...
- 3.6 C++继承机制下的构造函数
参考:http://www.weixueyuan.net/view/6363.html 总结: 在codingbook类中新增了一个language成员变量,为此必须重新设计新的构造函数.在本例中bo ...
- spin lock自旋锁 双链表操作(多线程安全)(Ring0)
通过spin lock自旋锁 ,为每个链表都定义并初始化一个锁,在需要向该链表插入或移除节点时不使用前面介绍的普通函数,而是使用如下方法: ExInterlockedInsertHeadList(&a ...
- 无法获取 vmci 驱动程序版本: 句柄无效
https://jingyan.baidu.com/article/a3a3f811ea5d2a8da2eb8aa1.html 将 vmci0.present = "TURE" 改 ...
- Centos7部署Flannel网络(八)
1.为Flannel生成证书 [root@linux-node1 ssl]# vim flanneld-csr.json { "CN": "flanneld", ...