动态传参,命名空间,嵌套,gloabal,nonlocal
一、动态传参
动态接受位置参数: *参数名
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的更多相关文章
- 函数动态传参,命名空间,gloabal,nonlocal关键字
一.函数参数->动态传参(形参的第三种) 动态参数分为两种: 1)动态接收位置参数 普通的位置传参: def func(quality_food,junk_food): print('我要吃', ...
- python记录_day10 动态传参 命名空间 作用域
一.动态传参 动态传参用到 *args 和 **kwargs ,*号表示接收位置参数,args是参数名:**表示接收关键字参数,kwargs是参数名 def chi(*food): print(foo ...
- python(动态传参、命名空间、函数嵌套、global和nonlocal关键字)
一.函数的动态传参 1.*args位置参数动态传参 def chi(*food): print(food) chi("烧烤","火锅","虾吃虾涮&q ...
- python-函数-动态传参,作用域的问题,函数嵌套,global nonlocal
⼀. 函数参数--动态传参 之前我们说过了传参, 如果我们需要给⼀个函数传参, ⽽参数⼜是不确定的. 或者我给⼀个 函数传很多参数, 我的形参就要写很多, 很⿇烦, 怎么办呢. 我们可以考虑使⽤动态参 ...
- python之路--动态传参,作用域,函数嵌套
一 . 动态传参(重点) * , ** * 与 ** * 在形参位置. * 表示不定参数, 接收的是位置参数 接收到的位置参数的动态传参: 都是元组 def eat(*food): # 在形参这里 ...
- python函数的动态传参.作用域与命名空间
一.动态传参1.*表示动态传参. 可以接受所有的位置参数传参的时候自动的把实参打包成元组 交给形参 def chi(*food): print(food) chi() # 动态传参可以不传参数 chi ...
- python-函数进阶-动态传参,名称空间,作用域的问题
一.函数的动态的动态参数 动态参数分为两种:动态接收位置参数.动态接收关键字参数. 1.*args 位置参数动态传参 # 顺序: 位置参数=>*args(arguments) => 默认 ...
- 2018.8.9 python中的动态传参与命名空间
主要内容: 1.函数参数 ----动态传参 2.名称空间与作用域 3.函数的嵌套 4.global,nonlocal关键字 一.函数参数 ------动态传参 形参的第三种:动态传参 动态传参分为两种 ...
- js函数动态传参
js函数体内可以通过arguments对象来接收传递进来的参数,利用这一对象属性可以动态传参. function box() { return arguments[0]+' | '+arguments ...
随机推荐
- Idea mybatis maper接口与mapper.xml文件关联 会根据接口中的方法点在mxl中生成相应sql方法
- 母鸡下蛋实例:多线程通信生产者和消费者wait/notify和condition/await/signal条件队列
简介 多线程通信一直是高频面试考点,有些面试官可能要求现场手写生产者/消费者代码来考察多线程的功底,今天我们以实际生活中母鸡下蛋案例用代码剖析下实现过程.母鸡在鸡窝下蛋了,叫练从鸡窝里把鸡蛋拿出来这个 ...
- javaweb登陆实例
1 <%@ page language="java" contentType="text/html; charset=UTF-8" 2 pageEncod ...
- DRF之访问权限控制和访问频率控制(节流)
权限控制 前言 用户验证用户权限,根据不同访问权限控制对不同内容的访问. 建议了解视图.token验证的内容. 使用流程 自定义访问权限类,继承BasePermission,重写has_permiss ...
- IDEA maven项目报错,找不到或无法找到主类
最近在写UDF,依赖复制的公司的依赖, <dependency> <groupId>org.apache.hive</groupId> <artifactId ...
- 四、hive安装
一.安装方式(内嵌模式,本地模式远程模式) 安装环境以及前提说明: Hive是依赖于hadoop系统的,因此在运行Hive之前需要保证已经搭建好hadoop集群环境. 本例中使用的hadoop版本为2 ...
- 容器编排系统K8s之节点污点和pod容忍度
前文我们了解了k8s上的kube-scheduler的工作方式,以及pod调度策略的定义:回顾请参考:https://www.cnblogs.com/qiuhom-1874/p/14243312.ht ...
- 剑指offer 树的基本操作:四种遍历方式
前序遍历 递归版 编程思想 即借助系统栈,效率较低.二叉树的前序遍历规则:1. 访问根结点: 2. 遍历左子树: 3. 遍历右子树 编程实现 //树的定义 struct TreeNode { int ...
- (二)数据源处理6-excel数据转换实战(下)
将结果的所有数据整理如下: {'api_case_01': [{'测试用例编号': 'api_case_01', '测试用例名称': '获取access_token接口测试', '用例执行': '是' ...
- Java 多线程读取文件并统计词频 实例 出神入化的《ThreadPoolExecutor》
重在展示多线程ThreadPoolExecutor的使用,和线程同步器CountDownLatch,以及相关CAS的原子操作和线程安全的Map/队列. ThreadPool主线程 1 import j ...