一、函数名的应用

1、函数名就是函数的内存地址

def func():
print(666)
func()
print(func) #函数的内存地址

2、函数名可以作为变量

def func1():
print(666)
f1 = func1
f2 = f1
f2() #执行结果为 666

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

def func1():
print(666)
def func2(x):
x()
func2(func1)

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

def wraaper():
def inner():
print('in the inner')
return inner
ret = wraaper()
ret()

5、函数名可以作为容器类类型的元素

def func1():
print('in zhe func1')
def func2():
print('in the func2')
def func3():
print('in the func3')
def func4():
print('in the func4')
l1 = [func1,func2,func3,func4]
for i in l1:
i()

以上函数名这种为:第一类对象

1、可以运行期创建

2、可用作函数参数或返回值

3、可以存入变量的实体

globals()  # 返回全局变量的一个字典
locals()  # 返回当前位置的局部变量的字典
def func1():
a = 2
b = 3
print(globals())
print(locals())
def inner():
c = 5
d = 6
print(globals()) # 全局变量的字典
print(locals()) # {'b': 3, 'a': 2}
inner()
print(globals()) # 全局变量的字典
print(locals()) # {'d': 6, 'c': 5}
func1()

二、闭包

2.1 闭包的作用:当程序执行时,遇到了函数执行,他会在内存中开辟一个空间,局部名称空间.如果函数内部形成了闭包,那么他就不会随着函数的结束而消失。

举例爬虫闭包:
from urllib.request import urlopen
def index():
url = "http://www.xiaohua100.cn/index.html"
def get():
return urlopen(url).read
return get
xiaohua = index() # get
content = xiaohua() # get()

2.2 什么是闭包?   内层函数对外层函数的变量(非全局变量)的引用,并返回。这样就形成了闭包

def wraaper():
name = 'alex' # 引用非全局变量
def inner():
print(name)
print(inner.__closure__) # (<cell at 0x00000223146565E8: str object at 0x000002231461A768>,)
inner() # 说明是一个闭包
return inner
wraaper()
name = 'alex'         # 引用全局变量
def wraaper():
def inner():
print(name)
print(inner.__closure__) # None,引用了全局变量,所以不是闭包
inner()
return inner
wraaper()

三、迭代器

3.1.1 可迭代对象

for i in 'abc':
print(i)
for i in 123:
print(i) #'int' object is not iterable 整数不是可迭代对象

注:可迭代对象:str、list、dict、tuple、set、rang()

3.1.2  判断一个对象是否是可迭代对象:

第一种方法:
s1 = [1,2,3]
print('__iter__'in dir(s1)) # True
第二种方法:
from collections import Iterable
print(isinstance('alex',Iterable)) # True

引导:这个方法还可以判断数据是什么数据类型

from collections import Iterable
print(isinstance('alex',str)) # True

3.2.1迭代器

判别方法:对象内部含有__iter__方法且含有__next__方法就是迭代器。

f = open('regsiter',encoding='utf-8')
print('__iter__' in dir(f)) # True
print('__next__' in dir(f)) # True
f.close()

3.2.2  可迭代对象——>>(转化成)迭代器

lis = [1,2,3]     # 可迭代对象
itel = lis.__iter__() # 迭代器<list_iterator object at 0x0000020750163DD8>
# itel = iter(lis) # 迭代器<list_iterator object at 0x0000020750163DD8>
print(itel)

3.2.3   迭代器如何取值? next一次,取一个值

lis = [1,2,3]     # 可迭代对象
itel = lis.__iter__() #(转化成)迭代器
print(itel.__next__()) print(itel.__next__()) print(itel.__next__())

3.2.4  可迭代对象与迭代器的区别

1、可迭代对象不能取值,迭代器是可以取值的
2、迭代器非常节省内存。
3、迭代器每次只会取一个值。
4、迭代器是单向的,一条路走到头
3.2.5  while 循环模拟for循环
for 循环
l1 = 'abcdefg'
for i in l1:
print(i)

while 循环模拟for循环

l1 = 'abcdef'
l = l1.__iter__() # 将可迭代对象转换成迭代器
while :
try:
print(l.__next__()) # 调用__next__()方法取值
except StopIteration: # 利用异常处理停止报错
break

												

python基础学习Day11 函数名的应用、闭包、迭代器的更多相关文章

  1. Python基础学习四 函数

    1.内置函数 Python内置了很多有用的函数,是可以直接调用的. 参考链接:https://docs.python.org/3/library/functions.html 调用函数的时候,如果传入 ...

  2. python基础学习Day9 函数的初识,实参、形参、

    1.函数 def my_len(): l = [,,,,,,] count = for i in l: count += print(count) my_len() 定义的my_len()方法时,其结 ...

  3. 【学习笔记】--- 老男孩学Python,day12 函数名的应用,闭包,迭代器

    1, 函数名的应用,第一类对象 函数名可以像变量一样进行使用 1.赋值 def func(): print("你吃了么?") # print(func) # a = func # ...

  4. python基础学习之函数进阶【匿名函数、作用域关系、闭包、递归】

    匿名函数 lambda的用法: lambda x:x+1 解释,同等于以下函数 def test(x): return x+1 因为没有函数名,所以称为匿名函数 只适用于简易的逻辑,复杂逻辑无法实现 ...

  5. python基础学习之函数基础和部分内置函数

    在函数调用的时候,必备参数必须要传入 函数定义: def  函数名: 代码块pass return  返回值 函数名命名规则: 字母.数字和下划线组成,和变量命名规则一致 pass在这里表示什么都没有 ...

  6. day12 python函数名的应用 闭包 迭代器

    day12 python   一.函数名的应用(是第一类对象)     函数名的命名规范和变量是一样的     函数名其实就是变量名 def func():     print('i am funct ...

  7. day 12 函数名的应用 闭包 迭代器

    今日主要内容 1, 函数名的应用,第一类对象 函数名可以像变量一样进行使用   #再函数名后面添加() 才是对函数的调用, 否则打印的是函数的内存地址 1.赋值 2.作为list元素 3.作为参数 d ...

  8. python基础学习2 函数变量与赋值

    学习的第一步,就是通常的输出函数:print() 1.基础主要学习了变量的赋值,变量名可以疑字母.数字.下划线(_)进行命名,但是不能以数字开头 变量的赋值:变量名 = 变量值 2.模块的导入,和调用 ...

  9. python基础学习Day10 函数形参的动态参数、*args **kwargs 命名空间 global 与 nonlocal

    一.函数形参的动态参数 原因:为了拓展,对于实参数量不固定,故需要万能参数,即动态参数, *args   **kwargs # def sum1(*args): # 在函数定义时,在*位置参数,聚合. ...

随机推荐

  1. 《Linux 性能及调优指南》写在后面的话

    感谢飞哥的翻译. 目前飞哥 (http://hi.baidu.com/imlidapeng)的网址已经不能访问了. <Linux 性能及调优指南>这本书的原文地址:http://www.r ...

  2. BOM跟DOM的区别和关联

    BOM 1. BOM是Browser Object Model的缩写,即浏览器对象模型. 2. BOM没有相关标准. 3. BOM的最根本对象是window. 从1可以看出来:BOM和浏览器关系密切. ...

  3. es6(15)--generator

    //generator处理异步,下一步用next,遇到return或者yied就会停止 { //generator基本定义 let tell=function* (){ yield 'a'; yiel ...

  4. python学习之----导航树

    findAll 函数通过标签的名称和属性来查找标签 .但是如果你需要通过标签在文档中的位 置来查找标签,该怎么办?这就是导航树(Navigating Trees)的作用.在第1 章里,我们 看过用单一 ...

  5. python - requests从excel中获取测试用例数据

    HttpRequests.py #-*- coding:utf-8 -*- import requests class HttpRequests(): def http_requests(self,u ...

  6. java中的Map

    Java8增强的Map集合 Map接口中定义了如下常用的方法. void clear():删除该Map对象中的所有key-value对. boolean containsKey(Object key) ...

  7. mysql source 命令导入不了sql!

    sql文件也是正常, 为什么就是导入不了呢?? 后面才发现,可能是编码被notepad++ 修改了—— 一看发现是UTF-8 无BOM,改回UTF-8格式编码 就正常了!! 虽然看到的都是正常汉字, ...

  8. 再谈java clone 以及 浅/深拷贝

    简单对象的拷贝,直接使用其clone方法 即可, 不会有什么问题: class Dog implements Cloneable public Dog clone() { int age; Strin ...

  9. spark shuffle 机制

    spark shuffle 分为两种 1.byPassSortShuffle 发生条件分区数<=200:无排序及聚合操作 主要是直接按照分区号写文件,有多少分区写多少文件 不做任何排序,简单直接 ...

  10. Python中的字符串方法

    Python中的字符串方法 字符串类即str提供了许多有用的方法来操纵字符串.具体来说,我们将讨论如下的方法. 搜索字符串内的子字符串. 测试字符串. 格式字符串. 转换字符串. 回顾前面的章节,方法 ...