一、动态传参

  动态接受位置参数:  *参数名

def eat(*food):
print(food) #多个参数传递进去,收到的内容是元祖tuple
eat("盖浇饭", "麻辣烫", "冰封") #('盖浇饭', '麻辣烫', '冰封')

  动态接收参数的时候要注意,动态参数必须在位置参数后面

  错误事例:

# def eat(*food, a, b):
# print(food, a, b)
# eat("盖浇饭", "麻辣烫", "冰封") #程序会报错,因为传递进去的位置参数都被*food接收了,a和b永远接收不到参数

  正确事例:

# def eat(a, b, *food):
# print(a, b, food)
# eat("盖浇饭", "麻辣烫", "冰封") #盖浇饭 麻辣烫 ('冰封',) #前两个参数用位置参数接收,后面的参数用动态参数接收
默认值参数写在动态参数前面,默认值只有一种情况可能会生效
# def eat(a, b, c='馒头', *food):
# print(a, b, c, food)
# eat("盖浇饭", "麻辣烫") #盖浇饭 麻辣烫 馒头 () 默认值生效
# eat("盖浇饭", "麻辣烫", "冰封") #盖浇饭 麻辣烫 冰封 ()
# eat("盖浇饭", "麻辣烫", "冰封", "烧烤") #盖浇饭 麻辣烫 冰封 (‘烧烤’,)

  默认值参数写在动态参数后面,所有的默认值都生效

# def eat(a, b, *food, c='馒头'):
# print(a, b, food, c)
# eat("盖浇饭", "麻辣烫") #盖浇饭 麻辣烫 () 馒头 默认值生效
# eat("盖浇饭", "麻辣烫", "冰封") #盖浇饭 麻辣烫 ('冰封',) 馒头 默认值生效
# eat("盖浇饭", "麻辣烫", "冰封", "烧烤") #盖浇饭 麻辣烫 ('冰封', '烧烤') 馒头 默认值生效

  动态参数接收关键字参数: **参数名

# def eat(**food):  #  **关键字参数
# print(food) 'good_food': '盖浇饭', 'junk_food': '麻辣烫', 'drink': '脉动'}
# eat(good_food='盖浇饭', junk_food="麻辣烫", drink="脉动") 参数传递进去,收到的内容是字典dict

  关键字参数必须要在位置参数后面,否则报错

def func(a, b, c, d):
print(a, b, c, d)
func(1, 2, c=3, 4) #报错

  最终顺序:位置参数 > *args > 默认值参数 > **kwargs

  接收所有的参数

# def func(*args, **kwargs):
# print(args, kwargs)
# func(1, 4, a=8, b = 9, c= 10) (1, 4) {'a': 8, 'b': 9, 'c': 10}

  动态参数的另一种传参方式

# def eat(*fruit):    # 聚合成元组
# print(fruit)
# lst = ["香蕉", "茄子", "黄瓜", "辣椒", "大白梨"]
# eat(lst[0], lst[1], lst[2], lst[3], lst[4]) ('香蕉', '茄子', '黄瓜', '辣椒', '大白梨')
# eat(*lst) # 这里的*表示的是把lst打散 ('香蕉', '茄子', '黄瓜', '辣椒', '大白梨')
def fun(*args):
print(args)
s = '臣妾做不到'(可迭代对象)
fun(*s) #('臣', '妾', '做', '不', '到') 以最小单元为元素,输出元祖

  字典打散,聚合,还是字典

def fun(**kwargs):
print(kwargs)
dic = {'a':1,'b':2}
fun(**dic) #{'a': 1, 'b': 2}

二、命名空间

  命名空间一共分为三种:

    全局命名空间:我们直接在py文件中,函数外声明的变量都属于全局命名空间

    局部命名空间:在函数中声明的变量会放在局部命名空间

    内置命名空间:存放了python解释器为我们提供的名字:input,print,str,list,tuple..都是内置命名空间

三种命名空间之间的加载与取值顺序:

加载顺序:内置命名空间(程序运行前加载)->全局命名空间(程序运行中:从上到下加载)->局部命名空间(程序运行中:调用时才加载)

取值顺序:

  在局部调用:局部命名空间->全局命名空间->内置命名空间

  在全局调用:全局命名空间->内置命名空间

综上所述,在找寻变量时,从小范围,一层一层到大范围去找寻。

作用域:作用域就是作用范围,按照生效范围可以分为全局作用域和局部作用域。

全局作用域:包含内置名称空间、全局名称空间,在整个文件的任意位置都能被引用、全局有效

局部作用域:局部名称空间,只能在局部范围内生效

a = 10  # 全局
def func(): # 全局
a = 40 # 局部
b = 20 # 局部
func() # 全局
 # print(globals()) # 打印全局作用域中的内容
# print(locals()) # 打印局部作用域中的内容

三、函数嵌套

    目前为止,所有的()表示的就是函数的调用

def f1():
  print(111)
  def f2():
  print(222)
f2()
f1() #111 222

四、global和nonlocal

    global: 寻找全局作用域中的内容
    nonlocal: 寻找上一级作用域中的内容, 但不能是全局的

# a = 10
# def func():
# global a # 加了个global表示不在局部创建这个变量,直接使用全局的a
# a = 20
# print(a)
# func()
# print(a)
a = 10
def func1():
a = 20
print(a)
def fun2():
nonlocal a # 调用上一级的变量, 且不能是全局
a = 30
print(a)
fun2()
print(a)
func1()
print(a)

动态传参,命名空间,嵌套,gloabal,nonlocal的更多相关文章

  1. 函数动态传参,命名空间,gloabal,nonlocal关键字

    一.函数参数->动态传参(形参的第三种) 动态参数分为两种: 1)动态接收位置参数 普通的位置传参: def func(quality_food,junk_food): print('我要吃', ...

  2. python记录_day10 动态传参 命名空间 作用域

    一.动态传参 动态传参用到 *args 和 **kwargs ,*号表示接收位置参数,args是参数名:**表示接收关键字参数,kwargs是参数名 def chi(*food): print(foo ...

  3. python(动态传参、命名空间、函数嵌套、global和nonlocal关键字)

    一.函数的动态传参 1.*args位置参数动态传参 def chi(*food): print(food) chi("烧烤","火锅","虾吃虾涮&q ...

  4. python-函数-动态传参,作用域的问题,函数嵌套,global nonlocal

    ⼀. 函数参数--动态传参 之前我们说过了传参, 如果我们需要给⼀个函数传参, ⽽参数⼜是不确定的. 或者我给⼀个 函数传很多参数, 我的形参就要写很多, 很⿇烦, 怎么办呢. 我们可以考虑使⽤动态参 ...

  5. python之路--动态传参,作用域,函数嵌套

    一 . 动态传参(重点)  * ,  ** * 与 ** * 在形参位置. * 表示不定参数, 接收的是位置参数 接收到的位置参数的动态传参: 都是元组 def eat(*food): # 在形参这里 ...

  6. python函数的动态传参.作用域与命名空间

    一.动态传参1.*表示动态传参. 可以接受所有的位置参数传参的时候自动的把实参打包成元组 交给形参 def chi(*food): print(food) chi() # 动态传参可以不传参数 chi ...

  7. python-函数进阶-动态传参,名称空间,作用域的问题

    一.函数的动态的动态参数 动态参数分为两种:动态接收位置参数.动态接收关键字参数. 1.*args  位置参数动态传参 # 顺序: 位置参数=>*args(arguments) => 默认 ...

  8. 2018.8.9 python中的动态传参与命名空间

    主要内容: 1.函数参数 ----动态传参 2.名称空间与作用域 3.函数的嵌套 4.global,nonlocal关键字 一.函数参数 ------动态传参 形参的第三种:动态传参 动态传参分为两种 ...

  9. js函数动态传参

    js函数体内可以通过arguments对象来接收传递进来的参数,利用这一对象属性可以动态传参. function box() { return arguments[0]+' | '+arguments ...

随机推荐

  1. [leetcode]103. Binary Tree Zigzag Level Order Traversal二叉树Z字形层序遍历

    相对于102题,稍微改变下方法就行 迭代方法: 在102题的基础上,加上一个变量来判断是不是需要反转 反转的话,当前list在for循环结束后用collection的反转方法就可以实现反转 递归方法: ...

  2. (class: org/apache/jasper/runtime/PageContextImpl, method: getELResolver signature: ()Ljavax/el/ELResolver;) Incompatible argument to

    网上大多都说是jsp版本原因: 引用: .............................................. ................................. ...

  3. Modbus 协议图文详解

    1.概论 Modbus是一种串行通信协议,由于其协议简单易用,且没有版权要求,目前已经成为工业领域通信协议的实时标准.ModBus协议是又施耐德电气的前身Modicon公司在1979年提出的.Modb ...

  4. 关于es6 let var const 以及Symbol的总结

    ```javascript //es6新增块级作用域.声明变量用关键字let const , // es5中只有函数作用域和全局作用域,声明变量用关键字var  // let 和const 声明的变量 ...

  5. 使用CSS的clip-path实现图片剪切效果

    最近有个业务需求:校对图片文本信息,如下图所示,当鼠标点击文本中某一行的时候,文本上会显示对应行图片同时左侧会显示对应位置的画框. clip-path 今天要说的主题是:如何剪切原图中的部分图片?(前 ...

  6. Linux下的strip命令学习

    strip strip是Linux下的一个命令.可以用于给应用脱衣服,帮助我们抹除一些调试信息.(虽然不知道具体是什么,但是会用就好了) 在嵌入式开发领域用到的应该比较多 首先,先写一个示例看看 // ...

  7. CSS卡片旋转

    html{ perspective: 800px; } body{ display:flex; flex-wrap: wrap; } .card{ transform-style: preserve- ...

  8. Nginx基础知识学习(安装/进程模型/事件处理机制/详细配置/定时切割日志)

    一.Linux下Nginx的安装 1.去官网 http://nginx.org/download/下载对应的Nginx安装包,推荐使用稳定版本. 2.上传Nginx到Linux服务器. 3.安装依赖环 ...

  9. 无限重置IDE过期时间插件 亲测可以使用

    相信破解过IDEA的小伙伴,都知道jetbrains-agent这个工具,没错,就是那个直接拖入到开发工具界面,一键搞定,so easy的破解工具!这个工具目前已经停止更新了,尽管还有很多小伙伴在使用 ...

  10. 以事实驳斥:改进你的c#代码的5个技巧(四)

    测试使用的环境:vs2019+.net core3.1 原文地址:https://www.cnblogs.com/hhhnicvscs/p/14296715.html 反驳第一条:如何检查代码中的空字 ...