一  首先我们学到函数的嵌套调用与定义:

1 函数嵌套
# def f1():
# print(f1)#我们这里如果输入f1那么输出的则是f1这个变量(函数)所在的地址。如果输入一个字符的话那么就直接输出该字符
# def f2():
# print(f2)
# def f3():
# print(f3)
# f3()
# # f2()
# f1()
那么我们在调用时,必须由外到内,也就是说我们如果想调用f3那么我们必须先通过f1才可以
2  函数的嵌套调用
在函数内又调用了其他函数。
def max2(x,y):
if x>y:
return x
else:
return y
print(max2(,)) def max3(x,y,z):
res1=max2(x,y)
res2=max2(res1,z)
return res2
res2=max3(,,)
print(res
二  名称空间    namespace
1. 名称空间顾名思义就是存放名字与值绑定关系的地方。
2. 名称空间分为三类:
(1)内置名称空间
存放python解释器自带的名字,如print(),len()等。
当解释器一启动就会生效,也就是说就可以对其进行调用 (2)全局名称空间
用来存放文件级别的名字,只要不在函数里面都叫全局变量。
只在文件执行的时候生效,在文件结束或者文件执行期间被删除则失效。
假如我们定义一个:
x=
def func():
name='egon'
del func#将func删除,
print('====') x=
def f1():
def f2():
print(x)
f2()
f1()
输出结果为1
 (3)局部名称空间

 用来存放函数内定义的名字,(函数的参数以及函数内的名字都存放于局部名称空间)。
只在函数调用时执行时短暂生效,函数调用结束则失效。 那么对于这三种名称空间,他们加载的顺序就是也就是他们在程序运行的一个加载先后顺序:
内置名称空间---〉全局名称空间---〉局部名称空间
那么查找在程序运行过程中查找的顺序是跟加载顺序相反的:
也就是:局部名称空间--〉全局名称空间---〉内置名称空间 作用域:作用域顾名思义就是作用的范围。
也就是函数所能访问到的范围: 全局作用域:
那么对于内置名称空间和全局名称空间来说,他们具有全局作用域,该范围内的名字会伴随程序整个运行周期,
也就是说程序不结束,那么在任何地方都能调用。 局部作用域:
只是包含局部的名称空间的名字,所以局部作用域只能在函数内部使用,调用函数时生效,调用结束后失效。 三 函数在python中是第一类对象(相当于变量) 1 可以被引用,像变量一样被引用:
变量
x=
y=x 函数
print('from')
def bar():
f=bar#这个时候bar作为一个变量赋给f,那么f()就相当于bar()。
f() ''' def foo():# foo=<function .... x1238102391203>
print('from foo') print(foo)
x=foo
print(x) l=[foo,]
print(l) def print_msg(x):
# print(x)
return x
a='sdfasdfasdfasdfadsf'
res=print_msg(foo)
print(res) '''

 2  可以当作参数传入:
 def func(a):#我们定义func为有参函数。
a+=
print(a)
func(x) def bar():
print('from bar,1')
def wrapper(func):#这一步相当于fun=bar
func()#那么相当于bar() wrapper(bar)#在这个过程就相当于调用函数wrapper(),我们把函数名bar传入,那么就相当于我们运行bar函数

3可以当作函数的返回值:
1#
x=
def foo():
return x#直接将返回值传给foo
res=foo()
print(res)

2#
x=1
def foo():              那么我们可以看出13与2#输出的结果是相同的。返回值会返回给函数本身。
print(x)
foo()
作为变量将x赋给foo() def bar(): print('from bar') def foo(func): return func print(bar) f=foo(bar) print(f) f() print(foo)#直接输出变量名,那么我们输出的是变量名所在的地址 x= print(x,id(x))
 4 可以当作容器类型的元素。
x=
l=[x]
print(l) def get():
print('from get')
def put():
print('from put')
l=[get,put]
print(l)
l[]()
 程序实例
def auth():
print('登录。。。。')
def register():
print('注册')
def search():
print('查看。。')
def pay():
print('支付。。') dic={
'':auth,
'':register,
'':search,
'':pay,
}
print(dic)
def interactive():
while True:
print('''
登陆
注册
查看
支付''')
choice=input('请输入编号:').strip()
if choice in dic:
dic[choice]()
else:
print('非法输入!') interactive()
l=[auth,register,search,]
print(l)
 四  闭包函数

闭:指的是定义在函数内部的函数。
作用域:在函数定义阶段就规定死了,与调用位置无关,不管在哪使用都要到原函数定义位置去找。
def outter():
x=
def inner():
x=
print('from inner',x) return inner#在这里我们返回inner就是为了得到inner这个函数,而outter只是起到一个包裹作用。 f=outter()#在调用函数outter时,将inner返回给outter这个函数名,也就是f=inner。
print(f)#输出的为变量inner,也就是inner所对应的地址。
f()#当我们把x=1注释掉之后,会变成x=。
def foo():
x=
f()
foo()

闭包函数:
1、定义在函数内的函数
2、并且该函数包含对外部函数作用域中名字的引用,该函数成为闭包函数。比如上述函数中inner引用了outer中的变量x。

闭包函数说白了就是将一个函数包进另一个函数里面,而且外层函数会给内层被包含函数定义好值,所以内部函数需要值时候先去自己所在层找。
找不到就去外层函数找,但是一般不会到全局找,因为全局变量大家都可以引用,所以闭包函数外层函数专门给闭包函数传值。
传值目的就是为了得到闭包函数的执行结果,所以return。
闭包函数包含对外部作用域的引用而非全局作用域的引用
在被包函数的头上,定义一个变量。
 
 

python之路之函数03的更多相关文章

  1. 小白的Python之路 day3 函数

    1.函数基本语法及特性 背景提要 现在老板让你写一个监控程序,监控服务器的系统状况,当cpu\memory\disk等指标的使用量超过阀值时即发邮件报警,你掏空了所有的知识量,写出了以下代码 1 2 ...

  2. Python之路 day3 函数定义 *args及**kwargs

    #!/usr/bin/env python # -*- coding:utf-8 -*- #Author:ersa import time # def logger(): # time_format ...

  3. python之路——初识函数

    阅读目录 为什么要用函数 函数的定义与调用 函数的返回值 函数的参数 本章小结 返回顶部 为什么要用函数 现在python届发生了一个大事件,len方法突然不能直接用了... 然后现在有一个需求,让你 ...

  4. python之路(九)-函数装饰器

    装饰器 某公司的基础业务平台如下: def f1(): print('这是f1业务平台') def f2(): print('这是f2业务平台') def f3(): print('这是f3业务平台' ...

  5. python 之路之函数01

    一   函数 1  那么要想学习函数,我们首先应该知道函数是什么? 我们这里所说的函数与数学中的函数是不同的概念,在这里我们可以把函数看成我们写代码过程中需要用到的工具. 2  那么这个‘工具’有什么 ...

  6. python之路--初识函数

    一 . 函数 什么是函数 f(x) = x + 1 y = x + 1 # 函数是对功能或者动作的封装 函数的语法 def 函数名(): 函数体 调用: 函数名() def play(): print ...

  7. python之路_函数实例及装饰器介绍

    一.习题讲解 1.写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组.例如:[(‘红心’,2), (‘草花’,2), …(‘黑桃,‘A’)] def cards(): num=[] for v ...

  8. python之路之函数02

    一  函数的参数: 我们把函数的参数分为形式参数和实际参数,简称形参和实参. 形参:在定义函数时,函数名括号内定义的参数. 实参:在调用函数时,函数名括号内需要用户传入的值. 注意: 实参值(相当于变 ...

  9. Python之路----生成器函数进阶

    def generator(): print(123) yield 1 print(456) yield 2 g = generator() ret = g.__next__() print('*** ...

随机推荐

  1. 2018C语言助教总结

    回顾 很荣幸得到各位老师的认可,担任计科3班和4班的C语言课程助教,很感谢车老师和牛老师一学期的帮助,使得我更好的担任助教一职.我班学生59名,很愉快的与同学们度过一个美好的学期,其实作为助教同样从学 ...

  2. linux搜索命令之find和grep

    在使用linux时,经常需要进行文件查找,其中查找的命令主要有find和grep.两个命令是有区的. 区别:(1)find命令是根据文件的属性进行查找,如文件名,文件大小,所有者,所属组,是否为空,访 ...

  3. hive中实现类似MySQL中的group_concat功能

    hive> desc t; OK id      string str     string Time taken: 0.249 seconds hive> select * from t ...

  4. 《DSP using MATLAB》Problem 3.18

    代码: %% ------------------------------------------------------------------------ %% Output Info about ...

  5. Mysql隔离级别 sql示例理解

    前言 事务要解决的是多线程并发修改数据库的问题.Mysql innodb 引擎支持事务.类似 Java 中的各种锁,例如乐观锁(CAS),读写锁,悲观锁.事务也有很多级别. 每个隔离级别要解决的问题都 ...

  6. 【java规则引擎】《Drools7.0.0.Final规则引擎教程》第4章 4.2 agenda-group

    转载:https://blog.csdn.net/wo541075754/article/details/75332720 agenda-group 规则的调用与执行是通过StatelessKieSe ...

  7. python 编码类型

    碰到各种编码混用, 则需要搞清楚. http://blog.csdn.net/lxdcyh/article/details/4018054. https://www.jianshu.com/p/a5b ...

  8. day28 python学习反射 sinstance和issubclass

    isinstance和issubclass isinstance(obj,cls)检查是否obj是否是类 cls 的对象 判断这个对象是不是这个类,或者是不是这个类的子类的实例化 class Foo( ...

  9. 多线程安全问题之Lock显示锁

    package com.hls.juc; import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.Reentr ...

  10. zmediaboard-Hi3518参数及配置

    1.12_13.uboot的烧写和flash分区1_21.12.1.裸机烧录uboot(1)什么叫裸机烧录?设备是空白的,未经烧录的,就叫裸机.(2)裸机烧录一个设备有2种方案:1是用外部烧录器来烧录 ...