第1章 名称空间
1.1 定义
1.2 变量运行流程
1.3 临时名称空间
1.4 python三种名称空间
第2章 作用域
2.1 作用域分类
2.2 加载顺序
2.3 取值顺序
函数嵌套
2.4 函数中嵌套函数
2.5 嵌套中的局部空间
第3章 内置函数
3.1 globals()
3.2 locals()
3.3 可变数据类型
第4章 关键字
4.1 global
4.2 nonlocal
第5章 函数名的应用
5.1 函数名对应内存地址
5.2 函数名可以作为容器类数据的元素
5.3 函数名可以作为函数的参数
5.4 函数名可以作为函数的返回值
5.5 函数名可以赋值
第6章 闭包
6.1 __closure__
6.2 闭包引申
第7章 装饰器基础
7.1 原始版测代码效率
7.2 改版1:封装一个函数
7.3 改版2测试多个函数
7.4 改版3同原函数
7.5 改版4 最简单的装饰器
7.6 改版5 语法糖 @
7.7 改版6带参数的装饰器
7.8 改版7:带返回值
7.9 装饰器本质-模板
第8章 拾遗
8.1 python2 里没有nonlocal
8.2 内存地址的坑

第1章 名称空间

1.1 定义

u  名称空间:变量与值的内存地址的对应关系

u  也称:全局名称空间,命名空间

1.2 变量运行流程

解释:当程序运行时,代码从上至下执行,他会将变量与值的关系存储在一个空间中,当调用变量时,找到命名空间中的关系,并找到内存地址,打印内存地址信息

1.3 临时名称空间

u  也称:局部名称空间

u  特点:

当程序遇到函数时,他会将函数名存在内存中,函数体漠不关心

当函数执行时,内存会临时开辟一个空间,存放函数体里面的代码

函数外面访问不到临时空间的内容,随着函数执行完,临时空间关闭释放

1.4 python三种名称空间

u  全局名称空间

u  局部名称空间

u  内置名称空间

例:

# !/usr/bin/env python

# -*- coding:utf-8 -*-

name = 'wang'##全局名称空间

def func1():

name = 'xiao'#局部名称空间

print(111)#内置名称空间

func1()

第2章 作用域

2.1 作用域分类

u  全局作用域

内置名称空间

全局名称空间

u  局部作用域

局部名称空间

2.2 加载顺序

内置名称空间  èè 全局名称空间  èè 局部名称空间

|-程序执行         |-函数调用

2.3 取值顺序

u  从小到大不可逆的去找,单向不可逆

u  引用不是改变

u  取值是从小到大取值LEGB

u  想改变上层空间的变量,要用到global nonlocal

 

函数嵌套

2.4 函数中嵌套函数

例:

def func1():

print(666)

def func2():

func1()

print(333)

def func3():

func2()

print(222)

print(111)

func3()

print(555)

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

111

666

333

222

555

2.5 嵌套中的局部空间

执行函数时开辟两个局部空间

def func1():

name =
'wang'

print(name)

def
func2():

name2
= 'su'

print(222)

print(333)

func2()

func1()

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

wang

333

222

全局名称空间只能局部引用不能改变

例:

count =1

def func1():

count =
count +1

print(count)

func1()

输出

File
"D:/python/untitled2/python_auto/lianxi3.py", line 51, in func1

count =
count +1

UnboundLocalError: local variable 'count'
referenced before assignment

#报错:改变count之前要先定义

例:正确定义后

count =1

def func1():

count2 =
count +1

print(count2)

func1()

输出

D:/python/untitled2/python_auto/lianxi3.py

2

第3章 内置函数

用来验证名称空间中所存的值

3.1 globals()

返回一个字典,字典里的内容是全局名称空间里的内容

3.2 locals()

返回 以一个字典,当前位置的所有变量

例:

sex = '男'

def func1():

name =
'wang'

age = 100

print(globals())

print(locals())

func1()

输出

'D:/python/untitled2/python_auto/lianxi3.py',
'__cached__': None, 'sex': '男', 'func1': <function
func1 at 0x0000000001D33E18>}

{'age': 100, 'name': 'wang'}

3.3 可变数据类型

解释:对于可变数据类型 list
dict set 不用global
nonlocal

例:

list1 = []

def func1():

list1.append(666)

func1()

print(list1)

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

[666]

第4章 关键字

4.1 global


可以引用并改变全局部变量


在局部作用域声明全局变量

例:应用改变

count =1

def func1():

global
count

count =
count +1

print(count)

func1()

print(count)

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

2

2

例:在局部作用域声明全局变量

def func1():

global  name

name =
'wang'

print(name)

func1()

print(name)

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

wang

wang

4.2 nonlocal

解释:不能操作全局变量,只能操作局部变量;从哪层引用的该变量,从那层开始全改变

不定义局部变量报错:UnboundLocalError:
local variable 'count' referenced before assignment

def func1():

count = 1

def
inner():

count
= count +1

print(count)

inner()

func1()

输出

File
"D:/python/untitled2/python_auto/lianxi3.py", line 67, in inner

count =
count +1

UnboundLocalError: local variable 'count'
referenced before assignment

例:nonlocal运用

def func1():

count = 1

def
inner():

nonlocal count

count
= count +1

print(count)

inner()

func1()

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

2

第5章 函数名的应用

解释:函数名定义规则与变量一样,区别是加()就能执行,像这样的函数名又叫:第一类对象

5.1 函数名对应内存地址

例:

def func1():

print(999)

print(func1)

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

<function func1 at 0x0000000000463E18>

5.2 函数名可以作为容器类数据的元素

例:

l1 = [func1,fun2,func3]

for i in l1:

i()

5.3 函数名可以作为函数的参数

def func1():

print(666)

def func2(x):

x()

print(222)

func2(func1)

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

666

222

5.4 函数名可以作为函数的返回值

例1:

#!/usr/bin/env python

# -*- coding:utf-8 -*-

#注册

def func1():

print(111)

def func2(x):

x()

print(222)

return x

ret = func2(func1)

ret()

输出

C:\python3\python.exe
D:/python/untitled2/python_4/python_lession.py

111

222

111

5.5 函数名可以赋值

例2:

def func1():

print(222)

return
111

f1 = func1

f2 = f1

f3 = f2

print(f3)

f3()

输出

C:\python3\python.exe
D:/python/untitled2/python_auto/lianxi3.py

<function func1 at 0x0000000001D13E18>

222

第6章 闭包

解释:内层函数对外层函数非全局变量的引用

6.1 __closure__

判断方法:函数名.__closure__,返回None不是闭包

例:

name = 'wang'

def wrapper(x):

def
inner():

print(x)

inner()

print(inner.__closure__)

wrapper(name)

输出

D:/python/untitled2/python_auto/lianxi3.py

wang

(<cell at 0x00000000021565E8: str object at
0x0000000001DBA260>,)

6.2 闭包引申

闭包的特性:若果说python解释器遇到了闭包,他有一个机制,这个闭包不会随着函数的结束而释放,后在一定时间后被垃圾回收机制释放掉。

第7章 装饰器基础

作用:在不影响函数执行的基础上,增加一些额外的功能,登录认证,打印日志

#!/usr/bin/env python

# -*- coding:utf-8 -*-

import time

7.1 原始版测代码效率

print(time.time())

def func1():

time.sleep(0.3)

print('非常复杂')

start_time = time.time()

func1()

end_time = time.time()

print('次函数的效率%s' %
(end_time-start_time))

7.2 改版1:封装一个函数

def func1():

time.sleep(0.3)

print('非常复杂。。。')

def func2():

time.sleep(0.3)

print('特别复杂。。。')

7.3 改版2测试多个函数

被测试函数当参数传入,可以测试多个函数执行效率

def timmer(f):

start_time = time.time()

f()

end_time
= time.time()

print('次函数的执行效率%s' % (end_time - start_time))

timmer(func1)

timmer(func2)

7.4 改版3同原函数

测试函数执行效率的同时,不要改变原函数的调用方式

def timmer(f):

start_time = time.time()

f()

end_time
= time.time()

print('次函数的执行效率%s' % (end_time - start_time))

f1 = func1

func1 = timmer

func1(f1)

7.5 改版4 最简单的装饰器

改版3虽然大体上满足了我的要求,但是增加两行代码,而且多了参数,不好,继续改,尽量不添加其他代码,而且做到调用时一模一样

def timmer(f):

def
inner():

start_time = time.time()

f()

end_time = time.time()

print('次函数的执行效率%s' % (end_time - start_time))

return
inner

func1 = timmer(func1)

func2 = timmer(func2)

func1()

func2()

7.6 改版5 语法糖 @

改版4每次测试一个函数的执行效率时都需要增加一行,func1 =
timmer(func1)代码,麻烦,python提出了一个语法糖 @。

def timmer(f):

def
inner():

start_time = time.time()

f()

end_time = time.time()

print('此函数的执行效率%s' % (end_time - start_time))

return  inner

@timmer

def func1():

time.sleep(0.3)

print('非常复杂。。。。')

func1()

7.7 改版6带参数的装饰器

被装饰的函数肯定要有参数的,你现在不能满足,解决这个问题。被装饰的函数带参数的装饰器

def timmer(f):

def
inner(*args,**kwargs):

start_time = time.time()

f(*args,**kwargs)

end_time = time.time()

print('此函数的执行效率%s' % (end_time - start_time))

return  inner

@timmer

def func1(a,b):

time.sleep(0.3)

print(a,b)

print('非常复杂。。。。')

@timmer  # func1
= timmer(func1)  inner

def func2(a,b,name,sex='man'):  # f(1,2,,sex='nv',name='alex')

time.sleep(0.3)

print(a,b,sex,name)

print('非常复杂......')

func2(1,2,sex='nv',name='alex')  # inner()

7.8 改版7:带返回值

被装饰的函数肯定要有返回值的,解决这个问题。被装饰的函数带参数且有返回值的装饰器

def timmer(f): 
# f = func2 函数名

def
inner(*args,**kwargs):  # args = (1,2),kwargs {sex:'nv',name:'alex'}

start_time = time.time()

ret =
f(*args,**kwargs)  #
f(1,2,,sex='nv',name='alex')

end_time = time.time()

print('此函数的执行效率%s' % (end_time - start_time))

return ret

return
inner

@timmer  #
func1 = timmer(func1)  inner

def func2(a,b,name,sex='man'):  # f(1,2,,sex='nv',name='alex')

time.sleep(0.3)

print(a,b,sex,name)

print('非常复杂......')

return
666

print(func2(1,2,sex='nv',name='alex'))  # inner()

def timmer(f):

def
inner(*args,**kwargs):

start_time = time.time()

ret =
f(*args,**kwargs)

end_time = time.time()

print('此函数的执行效率%s' % (end_time - start_time))

return ret

return
inner

@timmer

def func2(a,b,name,sex='man'):

time.sleep(0.3)

print(a,b,sex,name)

print('非常复杂......')

return
666

ret1 = func2(1,2,sex='nv',name='alex')

print(ret1)

7.9 装饰器本质-模板

装饰器的本质:是闭包

装饰器根本作用:在不影响原函数执行的基础上,增加一些额外的功能登录认证,打印日志等等。

def wrapper(f):

def
inner(*args,**kwargs):

"""被装饰函数执行之前的操作"""

ret =
f(*args,**kwargs)

"""被装饰函数执行之后的操作"""

return ret

return
inner

第8章 拾遗

8.1 python2 里没有nonlocal

8.2 内存地址的坑

def extendlist(val,list=[]):

list.append(val)

return
list

list1 = extendlist(10)

list2 = extendlist(123,[])

list3 = extendlist('a')

print('list1=%s'%list1)

print('list=%s'%list2)

print('list3=%s'%list3)

输出

C:\python3\python.exe
D:/python/untitled2/python_4/python_lession.py

list1=[10, 'a']

list=[123]

list3=[10, 'a']

python_函数嵌套(4)的更多相关文章

  1. JavaScript ES7 中使用 async/await 解决回调函数嵌套问题

    原文链接:http://aisk.me/using-async-await-to-avoid-callback-hell/ JavaScript 中最蛋疼的事情莫过于回调函数嵌套问题.以往在浏览器中, ...

  2. python之函数嵌套

    python很多特性与JavaScript是相似甚至相同的: 1. 无类型 2. 函数亦对象 .... 自然: python也允许函数嵌套, 这与JavaScript中函数闭包的作用一样....

  3. 不使用回调函数的ajax请求实现(async和await简化回调函数嵌套)

    在常规的服务器端程序设计中, 比如说爬虫程序, 发送http请求的过程会使整个执行过程阻塞,直到http请求响应完成代码才会继续执行, 以php为例子 $url = "http://www. ...

  4. Oracle之分组函数嵌套以及表连接

    --1 数据环境准备 scott 用户下面的emp,dept表 --2 要求 :求平均工资最高的部门编号,部门名称,部门平均工资 select d.deptno,d.dname,e.salfrom(s ...

  5. nodejs批量导入数据eventproxy(回调函数嵌套解决方案)使用实例

    回调函数嵌套解决方案——eventProxy API地址:https://github.com/JacksonTian/eventproxy 1.安装eventproxy 执行npm install ...

  6. python全栈开发-Day9 函数对象、函数嵌套、名称空间与作用域

    一 .函数对象 一 .函数是第一类对象,即函数可以当作数据传递 可以被引用 可以当作参数传递 返回值可以是函数 可以当作容器类型的元素 二. 利用该特性,优雅的取代多分支的if def foo(): ...

  7. python基础—函数嵌套与闭包

    python基础-函数嵌套与闭包 1.名称空间与作用域 1 名称空间分为: 1 内置名称空间   内置在解释器中的名称 2 全局名称空间   顶头写的名称 3 局部名称空间 2 找一个名称的查找顺序: ...

  8. python之函数对象、函数嵌套、名称空间与作用域、装饰器

    一 函数对象 一 函数是第一类对象,即函数可以当作数据传递 #1 可以被引用 #2 可以当作参数传递 #3 返回值可以是函数 #3 可以当作容器类型的元素 二 利用该特性,优雅的取代多分支的if de ...

  9. python基础知识13---函数对象、函数嵌套、名称空间与作用域、装饰器

    阅读目录 一 函数对象 二 函数嵌套 三 名称空间与作用域 四 闭包函数 五 装饰器 六 练习题 一 函数对象 1 函数是第一类对象,即函数可以当作数据传递 #1 可以被引用 #2 可以当作参数传递 ...

随机推荐

  1. 组合式+迭代式+链式 MapReduce

    1.迭代式mapreduce 一些复杂的任务难以用一次mapreduce处理完成,需要多次mapreduce才能完成任务,例如Pagrank,Kmeans算法都需要多次的迭代,关于mapreduce迭 ...

  2. ArchLinux最小化安装 必备库 常用命令

    铸成强大的工作站环境——ArchLinux最小化安装 所有问题归结起来,只是一个问题:ArchLinux最小化安装,需要安装哪些包? 1.bash//最基本的Bash Shell(必须)2.bzip2 ...

  3. all rows from client_id can grow infinitely compared to a single node when hashing by client_id

    all rows from client_id can grow infinitely compared to a single node when hashing by client_id Re: ...

  4. virtualbox创建centos7虚拟机

    安装Virtualbox 下载安装: 直接到官网上下载,https://www.virtualbox.org/wiki/Downloads 然后一键傻瓜式的安装即可. 设置默认虚拟电脑位置: 管理=& ...

  5. iOS 在UILabel显示不同的字体和颜色(ios6 and later)

    在项目开发中,我们经常会遇到在这样一种情形:在一个UILabel 使用不同的颜色或不同的字体来体现字符串,在iOS 6 以后我们可以很轻松的实现这一点,官方的API 为我们提供了UILabel类的at ...

  6. SDUT OJ 1598 周游列国

    周游列国 Time Limit: 1000ms   Memory limit: 32768K  有疑问?点这里^_^ 题目描述 大家都知道孔子吧,春秋战国时候的一个老头儿.当时出国还不用护照,所以他经 ...

  7. maven安装的详细步骤

    1.下载maven的bin,在apache官方网站下载.window系统下的下载红色方框的 2.解压后, 把bin的位置设在环境变量里,新建环境变量 MAVEN_HOME.这个配置是方便以后更换mav ...

  8. MYSQL进阶学习笔记六:MySQL视图的创建,理解及管理!(视频序号:进阶_14,15)

    知识点七:MySQL视图的创建(14) 视图的定义: 什么是视图: 视图数由查询结果形成的一张虚拟的表. 什么时候要用到视图? 如果某个查询结果出现的非常频繁,也就是,要经常拿这个查询结果来做子查询. ...

  9. Oracle:datafile删除后,重启server报ORA-01110

    模拟实验: 创建一个表空间后,直接把数据文件删除了:然后重启server. 1. create tablespace w56 datafile '/u01/app/oracle/product/10. ...

  10. docker hub下载慢解决方法 使用daocloud的mirror

    见:http://blog.csdn.net/dingsai88/article/details/52638758