一、内嵌函数&闭包

1、最好是访问全局变量而不是修改全局变量,修改全局变量Python会内部屏蔽(修改后,函数会内部创建一个和全局变量一抹一样的变量)

>>> count = 5
>>> def MyFun():
    count = 10
    print(10)
 
>>> MyFun()
10
>>> print(count)
5
>>>

---外部先定义了一个count的全局变量,然后MyFun()内部对count进行了修改,打印MyFun()函数发现,是修改后的count,但是在打印count变量,仍然是全局变量的值5,这说明函数内对全局变量的修改,会直接被屏蔽

2、global关键字(可以用global关键字进行修改)

>>> count =5
>>> def MyFun():
    global count
    count = 10
    print(10)

>>> MyFun()
10
>>> print(count)
10
>>>

3、内嵌函数(内部函数):函数内部创建另外一个函数

>>> def fun1():
    print('fun1正在被调用!')
    def fun2():
        print('fun2正在被调用!')
    fun2()
   
>>> fun1()
fun1正在被调用!
fun2正在被调用!

4、闭包:

def FunX(x):
    def FunY(y):
        return x*y
    return FunY

>>> FunX(8)(5)
40
>>> i = FunX(8)
>>> i
<function FunX.<locals>.FunY at 0x10598b400>
>>> i(5)
40

---闭包满足的两个条件:a、首先FunY是FunX的内部函数,并且FunY引用FunX的整个作用域  b、FunY引用FunX的变量x

---闭包的基本形式:

  在函数FunX中,定义FunY,FunY只能引用FunX定义的变量,之后FunX函数返回FunY函数的名字

>>> def fun1():
    x = 5
    def fun2():
        x *=x
        return x
    return fun2()

>>> fun1()
Traceback (most recent call last):
  File "<pyshell#75>", line 1, in <module>
    fun1()
  File "<pyshell#74>", line 6, in fun1
    return fun2()
  File "<pyshell#74>", line 4, in fun2
    x *=x
UnboundLocalError: local variable 'x' referenced before assignment
>>>

---报错的原因:(UnboundLocalError: local variable 'x' referenced before assignment)UnboundLocalError:赋值之前引用的局部变量'x',即:x是个局部变量,fun2赋值的时候x已经被屏蔽了,所以没办法引用

---解决方式:

A、采用数组这样的容器

>>> def fun1():
    x = [5]
    def fun2():
        x[0] *=x[0]
        return x[0]
    return fun2()

>>> fun1()
25

B、采用nonlocal关键字,强制声明x不是一个局部变量

>>> def fun1():
    x = 5
    def fun2():
        nonlocal x
        x *=x
        return x
    return fun2()

>>> fun1()
25

二、练习题

1、闭包举例:

def fun1():
    x = 5
    def fun2():
        nonlocal x
        x +=1
        return x
    return fun2
a = fun1()
print(a())
print(a())
print(a())

'''执行结果:
6
7
8 '''

2、统计下边这个字符串中各个字符出现的次数并找到尘封送给大家的一句话

str1 = 'aabbc'
list1 = []   #建立空列表的目的:为了后面的if each not in list1:判断去重

for each in str1:

if each not in list1: #目的:把str1中的字符添加到list1中,避免重复比较,
        if each == ' \n':
            print ('\\n',str1.count(each)) #str1.count(each)  计算str1数组里面each的个数
        else:
            print(each,str1.count(each))

list1.append(each)

'''执行结果:
a 2
b 2
c 1
'''

'''对比没有list1[]和if each not in list1,来体现去重 '''

print('=======')

str2 = 'aabbc'

for each in str1:
    if each == ' \n':
        print('\\n',str2.count(each))
    else:
        print(each,str2.count(each))

'''执行结果:
a 2
a 2
b 2
b 2
c 1
'''

#对比的结果:前后两个执行结果可以得知:引入list1[]空列表以及后续的判断,目的都是为了统计的去重操作

3、请用已学过的知识编写程序,找出小甲鱼藏在下边这个长字符串中的密码,密码的埋藏点符合以下规律:

a)、每位密码为单个小写字母

b)、每位密码的左右两边有且只有三个大写字每

def findSecret(str1):

    countA = 0 #统计前面的大写字母
countB = 0 #统计前面的小写字母
countC = 0 #统计后面的大写字母
length = len(str1) for i in range(length):
if str1[i] == '\n':
continue if str1[i].isupper(): #如果str1[i]是大写字母
if countB: #如果已经出现了小写字母
countC +=1 #统计后边的大写字母
else: #如果未出现小写字母
countC = 0 #清空后面的大写字母
countA +=1 #统计前面的大写字母 if str1[i].islower(): #如果str1[1]是小写字母
if countA != 3: #如果前面不是三个大写字母
countA = 0 #清空记录,重新统计
countB = 0
countC = 0
else: #如果前面是三个大写字母(满足条件)
if countB: #如果已经存在小写字母
countA = 0 #清空记录,重新统计
countB = 0
countC = 0
else: #如果只有一个小写字母
countB = 1 #标记一下countB
target = i #定位目标 if countA == 3 and countC ==3: #如果前后都是三个大写字母
if i+1 != length and str1[i+1].isupper():#如果第四个也是大写字母(不满足条件)
countB = 0 #清空记录B和C
countC = 0
else: #如果仅有三个大写字母(满足条件)
print(str1[target],end= '') #打印目标,结尾不换行
countA = 3
countB = 0 #清空记录B和C
countC = 0 return '' str2 = '''dQmaKZSdqKNrnvJlcyVMKuNWmuoOeyKecgjXbmSqnpjwJEaDYoehEklEgJyiksGxdEKgfYRXQecRZgfe
AAAbCCC''' print(findSecret(str2))

【Python020--内嵌函数和闭包】的更多相关文章

  1. 函数:内嵌函数和闭包 - 零基础入门学习Python020

    函数:内嵌函数和闭包 让编程改变世界 Change the world by program 内嵌函数和闭包 接下来这两节课我们谈的话题可能会"比较高级",所以如果是零基础的朋友, ...

  2. (十九)python 3 内嵌函数和闭包

    内嵌函数:函数里又嵌套一个函数 def fun1(): print('fun1()在被调用') def fun2(): print('fun2()在被调用') fun2() 闭包: 闭包是函数里面嵌套 ...

  3. 零基础入门学习Python(20)--函数:内嵌函数和闭包

    知识点 global关键字 使用global关键字,可以修改全局变量: >>> count = 5 >>> def Myfun(): count = 10 prin ...

  4. 小甲鱼零基础python课后题 P21 020函数:内嵌函数和闭包函数

    测试题 0.如果希望在函数中修改全局变量的值,应该使用什么关键字? 答:globe 1.在嵌套函数中,如果希望在内部函数修改外部函数的局部变量,应该使用什么关键字? 答:nonlocal 2.pyth ...

  5. Python21之内嵌函数和闭包

    一.内嵌函数 内嵌函数指的是在一个函数体内部定义的函数,可以称它为函数的函数,也就是子函数,外部的函数称之为母函数,就类似局部变量和全局变量 子函数体内定义的变量只在其函数内部有效,但其内部可以调用母 ...

  6. Makefile---make内嵌函数及make命令显示 (九)

    原创博文,转载请标明出处--周学伟http://www.cnblogs.com/zxouxuewei/ 这一节我们讲一下make的函数,在之前的章节已经讲到了几个函数:wildcard.patsubs ...

  7. Makefile所有内嵌函数

    一.文本处理函数以下是GNU make内嵌的文本(字符串)处理函数.1       $(subst FROM,TO,TEXT) 函数名称:字符串替换函数—subst. 函数功能:把字串“TEXT”中的 ...

  8. 3.MVC框架开发(Razor内嵌函数)

    1.建立没有返回值的Razor内嵌函数(但是能直接输出内容) 必须以@符号开头,没有返回值但能直接输出内容,比如: @helper showTitle(string strTitle){ ){ @(s ...

  9. Makefile学习(二)条件判断和内嵌函数

    第七章:Makefile的条件执行 条件语句可是是两个不同的变量.或者变量和常量值的比较: 7.1例子: 对变量“CC”进行判断,其值如果是“gcc ”那么在程序连接时使用库“libgnu.so”或者 ...

随机推荐

  1. webpack配置常用loader加载器

    webapck中使用loader的方法有三种 使用loader之前必须运行安装 : npm install --save-dev xxx-loader (1)通过CLI : 命令行中运行 webpac ...

  2. Python底层库的函数中from __future__ import absolute_import的作用

    在查看TensorFlow的底层优化器时候看到from __future__ import absolute_import 查找相关资料后发现 这个语句的意思是加入绝对引用的特征 直白的意思是,比如: ...

  3. python --- 字符编码学习小结

    上半年的KPI,是用python做一个测试桩系统,现在系统框架基本也差不多定下来了.里面有用到新学的工厂设计模式以及以及常用的大牛写框架的业务逻辑和python小技巧.发现之前自己写的代码还是面向过程 ...

  4. [ Learning ] Spring Resources

    1. Spring MVC Spring MVC原理及配置详解 springMVC系列之(三) spring+springMVC集成(annotation方式) Mybatis3+Spring4+Sp ...

  5. Rpgmakermv(30) GameQuest任务插件

    插件简介: 很牛X的任务插件(个人目前用过中的) 插件用法说明 Report any bugs, editor or plugin related here: http://forums.rpgmak ...

  6. Yii2 数据缓存/片段缓存/页面缓存/Http缓存

  7. Swift之关键字使用(I)

    static和class的使用 static 使用 在非class的类型(包括enum和struct)中,一般使用static来描述类型作用域.在这个类型中,我们可以在类型范围中声明并使用存储属性,计 ...

  8. sqoop从hive导入数据到mysql时出现主键冲突

    今天在将一个hive数仓表导出到mysql数据库时出现进度条一直维持在95%一段时间后提示失败的情况,搞了好久才解决.使用的环境是HUE中的Oozie的workflow任何调用sqoop命令,该死的o ...

  9. 深度学习之循环神经网络RNN概述,双向LSTM实现字符识别

    深度学习之循环神经网络RNN概述,双向LSTM实现字符识别 2. RNN概述 Recurrent Neural Network - 循环神经网络,最早出现在20世纪80年代,主要是用于时序数据的预测和 ...

  10. 关于Vue中的 render: h => h(App) 具体是什么含义?

    render: h => h(App) 是下面内容的缩写: render: function (createElement) { return createElement(App); } 进一步 ...