关键字:return

自定义函数的返回值,return可以把值返回到函数的调用处
        1.return+六大标准数据类型,还有类和对象,函数
        如果不定义return,默认返回的是None
        2.在执行return之后,立刻终止函数,后面的代码不执行

# 1.return的返回类型
def func():
# return 1
# return 3.14
# return "abc"
# return []
# return ()
# return {"a":1}
pass
res=func()
# 如果不定义return,默认返回的是None
print(res)
# 2.在执行完return 之后,立刻终止函数,后面的代码不执行
def func():
print(1)
print(2)
return 3 # 立刻终止函数,后面的print(4)和print(5)不执行
print(4)
print(5)
res =func()
print(res) def func():
for i in range(3):
if i==2:
return 1
print(i)
res = func()
print(res) # 0 1 1
# 3.模拟简单的计算器 + - * /
def func(sign,num1,num2):
if sign=="+":
res= num1+num2
elif sign=="-":
res =num1-num2
elif sign=="*":
res = num1*num2
elif sign=="/":
if num2 ==0:
return "除数不能为0,老弟"
res = num1/num2
else:
return "这个本计算器真算不了"
return res res = func("+",3,5)
res = func("-",10,20)
res = func("*",10,20)
res = func("/",20,10)
res = func("/",20,0)
res = func("&",20,0)
print(res)

全局变量和局部变量

局部变量:在函数内部定义的变量(局部命名空间)
全局变量:在函数外部定义的或者使用global在函数内部定义(全局命名空间)
作用域:作用的范围

局部变量作用域:在函数的内部
全局变量作用域:横跨整个文件

生命周期:
内置变量>全局变量>局部变量

1.局部变量

# 1.局部变量
def func():
# 定义局部变量
a=5
# 获取局部变量
print(a)
# 修改局部变量
a=10
print(a)
func()
print(a) # error 不能在全局调用局部变量

2.全局变量

# 2.全局变量
# 定义全局变量
b=10
# 获取全局变量
print(b)
# 修改全局变量
b=20 def func():
# 可以在函数内部获取全局变量
print(b)
func()

3.使用global在函数内部创建全局变量

# 3.使用global在函数内部创建全局变量
def func():
global c
c=200
func()
print(c)

4.使用global在函数内部修改全局变量

# 4.使用global在函数内部修改全局变量
d=300
def func():
global d
d=400
func()
print(d)

5.总结:

可以使用global关键字在函数内部定义一个全局变量
也可以使用global关键字在函数内部修改一个全局变量

函数名的使用

1.函数名是一个特殊的变量,可以把函数当做变量对它赋值

def func():
print("我是func函数")
return 1 # 1.函数名是个特殊的变量,可以当做变量赋值
a="你好"
print(a)
a=func()
# a() # 函数可以像变量一样销毁
del a
a()

2.函数名可以作为容器类型数据的参数

# 2.函数名可以作为容器类型数据的元素
def func1():
print("我是func1函数")
def func2():
print("我是func2函数")
def func3():
print("我是func3函数") lst=[func1,func2,func3]
for i in lst:
print(i)
i() # func1() func2() func3()

3.函数名可以作为函数的参数

# 3.函数名可以作为函数的参数
def func3():
print("我是func3函数") def func4(f):
f() # 我是func3函数 func4(func3)

4.函数名可以作为函数的返回值

# 4.函数名可以作为函数的返回值
def func(f):
return f
res = func(func2) # f---> func2 -----> res=func2()
res()

5.__doc__ 或者help查看文档

#  __doc__ 或者help查看文档
def func(a):
"""
功能:xxxx
参数:a
返回值:1
"""
print("xxxx")
return 1 help(func)
res = func.__doc__
print(res) 输出结果: 功能:xxxx
参数:a
返回值:1

函数的嵌套

1.一个简单的例子

def outer():
def inner():
print("我是inner函数")
inner()
outer()
inner() # 调用外部函数时,内部函数不可以再函数外部调用!

1.内部函数可以直接在函数外部调用吗?不行
2.调用外部函数后,内部函数可以在函数外部调用吗?不行
3.内部函数可以在函数内部调用吗? 可以
4.内部函数在函数内部调用时,是否有先后顺序?有!必须先定义再调用

2.函数嵌套案例

# 外层是outer,内层是inner,最里层是smaller,调用smaller里面的所有代码

def outer():
def inner():
def smaller():
print("我是smaller函数",id)
smaller()
inner()
outer()

3.LEGB原则

找寻变量的调用顺序采用LEGB原则,即就近原则
B- Builtin(Python):python内置模块的命名空间 (内建作用域)
G- Global(module):函数外部所在的命名空间(全局作用域)
E -Enclosing function locals:外部嵌套函数的作用域(嵌套作用域)
L -Local(function):当前函数内的作用域(局部作用域)
依据就近原则 从下向上 由里向外 依次寻找

nonlocal关键字

nonlocal 遵循LEGB就近找变量原则
        1.找当前空间上一层的局部变量进行修改
        2.如果找不到,会继续向上寻找
        3.最后什么也没有,直接报错

1.找当前空间上一层的局部变量进行修改

# 1.找当前空间上一层的局部变量进行修改
def outer():
a=100
def inner():
nonlocal a
a=200
print(a) # 200
inner()
print(a) # 200
outer()

2.如果找不到,会继续向上寻找

# 2.如果找不到,会继续向上寻找
def outer():
a=100
def inner():
def smaller():
nonlocal a
a=400
print(a) # 400
smaller()
print(a) # 400
inner()
print(a) # 400
outer()

3.注意点:nonlocal只能修改局部变量

# 3.注意点:nonlocal只能修改局部变量
a=100
def outer():
def inner():
def smaller():
nonlocal a # nonlocal只能修改局部变量,而本程序中第一行的a是全局变量,nonlocal无法修改
a=400
print(a)
smaller()
print(a)
inner()
print(a)
outer()

4.不使用nonlocal修改局部变量--->只能适用于列表

# 4.不使用nonlocal修改局部变量
def func():
lst=[1,2,3,4]
def inner():
lst[-1]=10
inner()
print(lst)
func()

globals和locals

1.locals 获取当前作用域中所有变量

locals 如果在全局,调用locals之后,获取的是打印之前的所有变量,返回字典,全局空间作用域
locals 如果在局部,调用locals之后,获取的是调用之前的所有变量,返回字典,局部空间作用域

# locals 在全局:获取打印之前的所有变量
def func():
ff = 123
a = 1
b = 2
res = locals()
c = 3
print(res) # 是一个大字典,里面有很多键值对,a:1 b:2 c:3均可以打印出来(截止到打印之前)
d = 4 # d:4 不会被打印
# locals 在全局
a1 = 10
def func():
a = 1
b = 2
res = locals()
c = 3
print(res) # a:1 b:2 会被打印出来 截止到调用local()之前的都会被打印出来
d = 4
a2 = 20
func()
a3 = 30

2.globals 只获取全局空间中所有变量

globals 如果在全局,调用globals之后,获取的是打印之前的所有变量,返回字典,全局空间作用域
globals 如果在局部,调用globals之后,获取的是调用之前的所有变量,返回字典,全局空间作用域

# global 在全局
def func():
ff = 123
a = 1
b = 2
res = globals() # a:1 b:2 c:3 截止到打印之前
c = 3
print(res)
d = 4
# global 在局部
a1 = 10
def func():
a = 1
b = 2
res = globals()
c = 3
print(res)
d = 4
a2 = 20
func() # globals() a1:10 a2:20 截止到调用处
a3 = 30

3.globals 动态批量创建全局变量

# 1.用字符串定义全局变量
dic = globals() # 必须是global定义的字典,普通字典无效
print(dic) # 返回的是系统的字典
# 在全局的字典当中,通过添加键值对,自动创建全局变量
# 对应的键时变量名,对应的值是变量指向的值
dic["name"] = "致和"
print(name) # 致和
# 2.批量定义全局变量
def func():
dic = globals()
# 通过在全局系统字典当中,添加键值对,批量创建变量
for i in range(1,6):
# "a%d" % (1) => "a1" "a%d" % (2) => "a2"
dic["a%d" % (i)] = i # 1~5 func()

day11:return关键字&全局/局部变量&函数名的使用&函数的嵌套&nonlocal关键字&locals/globals的更多相关文章

  1. Delphi 调用C/C++的Dll(stdcall关键字, 会导致函数名分裂. 此时函数名变成_stdadd@8)

    delphi调用C++写的Dll, 当然这个Dll要求是非MFC的Dll, 这样子才能被delphi调用. 根据C++定义函数的情况, Delphi有不同的相对应的处理方法.1. 声明中不加__std ...

  2. c++入门之——const在函数名前面和函数后面的区别

    class Test(){ public: Test(){} const int foo(int a); const int foo(int a) const; }; 一.概念 当const在函数名前 ...

  3. php函数名前添加& 函数的引用返回

    function &test(){ static $b=0; $b= $b+1; return $b; } $a= test(); echo $a,"\n"; $a = 3 ...

  4. "函中函" -------------------- func2(func) -------------- 函数名可以当做函数的参数

    def func(): print("吃了么")def func2(fn): print("我是func2") fn() # 执⾏传递过来的fn # 即 fn替 ...

  5. 用var 变量=函数名 方式调用函数时如何传值的问题

    通过:xmlhttp.onreadystatechange= function(){FuncName(param)};orxmlhttp.onreadystatechange= new Functio ...

  6. day09-Python运维开发基础(函数收集参数、命名关键字参数与返回值、函数名的特殊使用及 全局/局部变量详解)

    1. 函数收集参数.命名关键字参数与返回值.函数名的特殊使用 # ### 默认形参 和 关键字实参 # 默认形参和 关键字实参 在写法上是一样 # 函数的定义处 """默 ...

  7. 记录我的 python 学习历程-Day11 两个被忽视的坑、补充知识点、函数名的应用、新版格式化输出、迭代器

    补充知识点 函数形参中默认参数的陷阱 针对不可变数据类型,它是没有陷阱的 def func(name, sex='男'): print(name) print(sex) func('Dylan') # ...

  8. python 全栈开发,Day11(函数名应用,闭包,装饰器初识,带参数以及带返回值的装饰器)

    一.函数名应用 函数名是什么?函数名是函数的名字,本质:变量,特殊的变量. 函数名(),执行此函数. python 规范写法 1. #后面加一个空格,再写内容,就没有波浪线了. 2.一行代码写完,下面 ...

  9. python day11 ——1. 函数名的使⽤ 2. 闭包 3. 迭代器

    ⼀. 函数名的运⽤. 1.函数名的内存地址 def func():    print("呵呵") print(func) 结果: <function func at 0x11 ...

  10. python基础学习Day11 函数名的应用、闭包、迭代器

    一.函数名的应用 1.函数名就是函数的内存地址 def func(): print(666) func() print(func) #函数的内存地址 2.函数名可以作为变量 def func1(): ...

随机推荐

  1. PTA一元多项式的乘法与加法运算 另一种算法

    设计函数分别求两个一元多项式的乘积与和. 输入格式: 输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数).数字间以空格分隔. ...

  2. spring中事物是怎么实现的?

    Spring容器事务 声明式和编程式 当需要用到事务操作的地方很少的时候,那么就可以使用编程方式 TransactionTemplate,它不会建立很多事务代理.但是,如果程序中用到大力的事务操作,声 ...

  3. heimaJava17

    java IO流 缓冲流 概念 缓存流也称为高效流.或者高级流.之前学习的字节流也可以称为原始流 作用:缓冲流自带缓冲区.可以提高原始字节流.字符流读写数据的性能 分类 字节缓冲流 字节缓冲输入流:B ...

  4. 【搭建】【转】PPTP

    https://blog.51cto.com/10802692/2177227?SOURCE=DRA

  5. 小程序使用svga

     svga 是一种动画格式.不仅可以在 ios,android,flutter,web 上使用,小程序也支持.设计师使用 after effects 或是 animate 进行动画设计.设计师导出工具 ...

  6. CH573 CH579 CH582程序烧录讲解

    WCH的蓝牙芯片CH57x/CH58x系类大部分是支持串口烧录.USB烧录和LINK烧录的,除了一些特殊的封装,如571K,它引脚较少,只支持串口免按键烧录. 仿真下载:ARM内核的CH579支持Jl ...

  7. xcodeproj Building for iOS, but the linked and embedded framework ‘xxx.framework’ was built for iOS + iOS Simulator.

    一.报错 报错内容大致如下 /xxxx/xxx.xcodeproj Building for iOS, but the linked and embedded framework 'xxx.frame ...

  8. 英码科技边缘计算智慧工地解决方案——给工地戴上AI“安全帽”

    据统计显示,2021年全国共发生房屋市政工程生产安全事故734起,死亡840人:且近3年来,工地事故数量.死亡人数连续攀升.这不仅仅是一个普通的数字,每个数字都代表一个独特.鲜活的生命.为什么每年会发 ...

  9. Keil Jlink没法找到STM32H750

    https://www.amobbs.com/thread-5713382-1-1.html MDK使用的是5.32,jlink使用的是9.2jlink驱动使用的是6.44b 删除工程下的JLinkS ...

  10. beta冲刺:总结随笔

    这个作业属于哪个课程 <班级的链接> 这个作业要求在哪里 <作业要求的链接> 这个作业的目标 beta冲刺总结 作业正文 .... 其他参考文献 ... 一.预期计划 | 6. ...