# def fn():
#     print("我叫fn")

# fn()
# print(fn)  # <function fn at 0x0000000001D12E18>
# fn()
# gn = fn # 函数名可以进行赋值
# print(gn)
# gn()

# fn = 666
# print(fn) # 666

# def func1():
#     print("朱祁镇")
#
# def func2():
#     print("徐阶")
#
# def func3():
#     print("王阳明")
#
# def func4():
#     print("魏忠贤")
#
# lst = [func1, func2, func3, func4] # 函数+() 就是调用.
# print(lst)
#
# # lst[0]()
# # for el in lst: #  el是列表中的每一项.
# #     el() # 拿到函数. 执行函数
#
#
# a = 10
# b = 20
# c = 30
# lst = [a, b, c]
# print(lst)

# def wrapper():
#     def inner():
#         print("我的天, 还可以扎样写")
#     print(inner) # <function wrapper.<locals>.inner at 0x00000000028989D8>
#     inner()
#     return inner
#
# ret = wrapper() # <function wrapper.<locals>.inner at 0x00000000028989D8>
# print(ret)
# ret()

# def wrapper():
#     def inner():
#         print("哈哈哈")
#     return inner  # 函数名可以像返回值一样返回
#
# ret = wrapper()
# ret() # 在函数外面访问了函数内部的函数
# ret()
# ret()

#
# def func1():
#     a = 10
#     return a
# print(func1())

# 函数可以作为参数进行传递

def func1():
    print("谢晋")

def func2():
    print('杨士奇')

def func3():
    print('徐渭')

def func4():
    print("柳如是")

# 代理. 装饰器的雏形
def proxy(a): # a就是变量. 形参
    print("我是代理")
    a()
    print("代理执行完毕")
# 闭包的优点:
#   1, 可以保护变量不被其他人侵害
#   2, 保持一个变量常驻内存

# def wrapper():
#     a = "哈哈" # 不安全的一种写法
#     name = "周杰伦"
#     def inner():
#         print(name) # 在内层函数中使用了外层函数的局部变量
#         print(a)
#     def ok():
#         nonlocal a
#         a = 108
#         print(a)
#     return inner  # 返回函数名
#
# ret = wrapper()
# ret()
#
# def ok():
#     global a
#     a = 20
#     print(a )

# def wrapper():
#     name = "周杰伦" # 局部变量常驻与内存
#     def inner():
#         print(name) # 在内层函数中使用了外层函数的局部变量
#     return inner  # 返回函数名
#     # inner()
#
# ret = wrapper() # ret是一个内层函数
# ret() # ret是inner, 执行的时机是不确定的, 必须保证里面的name必须存在

# 超级简易版爬虫
# from urllib.request import urlopen # 导入一个模块
# # 干掉数字签名
# import ssl
# ssl._create_default_https_context = ssl._create_unverified_context
#
#
# def func():
#     # 获取到网页中的内容, 当网速很慢的时候. 反复的去打开这个网站. 很慢
#     content = urlopen("https://www.dytt8.net/").read()
#
#     def inner():
#         return content.decode("gbk") # 网页内容
#     return inner
#
# print("开始网络请求")
# ret = func() # 网络请求已经完毕
# print("网络请求完毕")
# print("第一次", ret()[5])
# print("第二次", ret()[5]) #

def wrapper():
    name = "alex"
    def inner():
        print("胡辣汤")
    print(inner.__closure__) # 查看是否是闭包. 有内容就是闭包, 没有内容就不是闭包
    inner()

wrapper()

# s = "今天下午考试. 你们还要睡觉吗?"
#
# for c in s: # 字符串是一个可迭代对象
#     print(c)

# for c in "哼哼哈哈":
#     print(c)
#
# for i in 123: # 'int' object is not iterable
#     print(i)

# dir() 可以帮我们查看xxx数据能够执行的操作
# print(dir(str)) # __iter__
# print(dir(int)) # 没有__iter__
# print(dir(list)) # 有__iter__
# print(dir(dict)) # 有__iter__
# print(dir(bool)) # 没有__iter__
# for i in True: # 'bool' object is not iterable
#     print(i)

# print(dir(range))
# f = open("呵呵", mode="r", encoding="utf-8")
# print(dir(f))

# 共性:所有带有__iter__的东西都可以进行for循环, 带有__iter__的东西就是可迭代对象

# lst = ["贾樟柯", "李安", "杨德昌", "王家卫"]
#
# # 1. 只能向下执行, 不能反复
# # 2. 结束的时候会给我们扔出来一个错误 StopIteration
# # 3. 整合所有的数据类型进行遍历(int,bool除外)
#
# # print("__iter__" in dir(lst))
# it = lst.__iter__()  # 拿到的是迭代器 <list_iterator object at 0x0000000001DCC160>
#
# print(it.__next__()) # 下一个
# print(it.__next__()) # 下一个
# print(it.__next__()) # 下一个
# print(it.__next__()) # 下一个
# # print(it.__next__()) # 下一个 # StopIteration 停止迭代
# # 想回去
# it = lst.__iter__() # 只能重新获取迭代器

# s = {"张无忌", "贾樟柯", "宝宝", "风扇哥", "门神"}
# it = s.__iter__()
# print(it.__next__())
# print(it.__next__())
# print(it.__next__())
# print(it.__next__())
# print(it.__next__())

# lst = ["海尔兄弟", "阿童木", "葫芦娃", "舒克贝塔", "大风车"]
# # 模拟for循环 for el in lst:
# it = lst.__iter__() # 获取到迭代器0
# while 1: # 循环
#     try: # 尝试
#         el = it.__next__() # 那数据
#         print(el)
#     except StopIteration: # 出了错误, 意味着数据拿完了
#         break # 结束循环

# 官方通过代码判断是否是迭代器
# 借助于两个模块 Iterator迭代器, Iterable可迭代的
# from collections import Iterable, Iterator
#
# lst = [1,2,3]
# # print(lst.__next__())
#
# print(isinstance(lst, Iterable)) # xxx是否是xxx类型的. True
# print(isinstance(lst, Iterator)) # False
#
# it = lst.__iter__()  # 迭代器一定可迭代,  可迭代的东西不一定是迭代器
#
# print(isinstance(it, Iterable)) # xxx是否是xxx类型的. True
# print(isinstance(it, Iterator)) # True
#
# for el in it:
#     print(el)

proxy(func1)
proxy(func3)
proxy(func4)

python-第一类对象,闭包,迭代器的更多相关文章

  1. python 第一类对象 闭包 迭代器

    ########################总结########################### 1. 函数名 -> 第一类对象 函数名就是变量名. 函数可以赋值 函数可以作为集合类的 ...

  2. python第一类对象,闭包,迭代器

    一.第一类对象 第一类对象 -> 函数名 -> 变量名 1.特征:     函数对象可以像变量一样进行赋值     还可以作为列表的元素进行使用     还可以作为返回值返回     还可 ...

  3. python 函数名的应用(第一类对象),闭包,迭代器

    1.函数名的应用(第一类对象) 函数名的命名规范和变量是一样的 函数名其实就是变量名 可以作为列表中的元素进行储存. def func1(): pass def func2(): pass lst = ...

  4. 巨蟒python全栈开发-第11天 第一类对象 闭包 迭代器

    一.今日主要内容总览(重点) 1.第一类对象->函数名=>变量名 (1)函数对象可以像变量一样进行赋值 (2)还可以作为列表的元素进行使用 (3)还可以作为返回值返回 (4)还可以作为参数 ...

  5. Python_Mix*函数名的使用以及第一类对象,闭包,迭代器,for循环的内部机制

    一:函数名的应用(第一类对象) 函数名的命名规范和变量是一样的,函数名其实就是变量名, 0)函数名可以赋值给其他变量 def func(): #定义一个名为func的函数 print('my ange ...

  6. day11 第一类对象 闭包 迭代器

    今日主要内容: 1 . 第一类对象 -->函数名--> 变量名 2. 闭包 -->函数的嵌套 3. 迭代器 --> 固定的思想 for 循环 第一类对象  : 函数对象介意向变 ...

  7. 完全理解 Python 迭代对象、迭代器、生成器(转)

    完全理解 Python 迭代对象.迭代器.生成器 本文源自RQ作者的一篇博文,原文是Iterables vs. Iterators vs. Generators » nvie.com,俺写的这篇文章是 ...

  8. 完全理解 Python 迭代对象、迭代器、生成器

    完全理解 Python 迭代对象.迭代器.生成器 2017/05/29 · 基础知识 · 9 评论 · 可迭代对象, 生成器, 迭代器 分享到: 原文出处: liuzhijun    本文源自RQ作者 ...

  9. python记录_day11 闭包 迭代器

    一.第一类对象: 函数名是一个变量,可以当普通变量使用,但它又是一个特殊的变量,与括号配合可以执行函数. 函数名的运用 1.单独打印是一个内存地址 2.可以给其他变量赋值 3.可以作为容器类变量的元素 ...

  10. 完全理解Python迭代对象、迭代器、生成器

    在了解Python的数据结构时,容器(container).可迭代对象(iterable).迭代器(iterator).生成器(generator).列表/集合/字典推导式(list,set,dict ...

随机推荐

  1. JDK中关于BIO,NIO,AIO,同步,异步介绍

    在理解什么是BIO,NIO,AIO之前,我们首先需要了解什么是同步,异步,阻塞,非阻塞.假如我们现在要去银行取钱: 同步 : 自己亲自出马持银行卡到银行取钱(使用同步IO时,Java自己处理IO读写) ...

  2. js 动画效果实现

    1. 实现方式 - 应用场景 自己写 - 简单的.不用 jq 的项目 jq - 普通动画 成熟插件 - 复杂动画 2. 相关文章 JavaScript基于时间的动画算法 九种原生js动画效果 Twee ...

  3. WCF 一步一步 发布 WCF服务 到 IIS (图)

    WCF 一步一步 发布 WCF服务 到 IIS (图) 使用VS自带的WCFSVCHost(WCF服务主机)发布WCF服务,时刻开发人员测试使用. 下面我们来看一下如何在IIS中部发布一个WCF服务. ...

  4. 11月26日 用seed,预加载种子文件; Case 条件语句。网址的参数如何传递,; Query--自定义scopes

    在seed文件中输入一些预加载的种子job,注意属性和值都要有:  ❌错误,我输入contact_email的时候value值是空的,这样不能正确生成. 正确✅: for i in 1..10 do ...

  5. android -------- ConstraintLayout介绍 (一)

    ConstraintLayout 翻译为 约束布局,也有人把它称作 增强型的相对布局,由 2016 年 Google I/O 推出. 扁平式的布局方式,无任何嵌套,减少布局的层级,优化渲染性能.从支持 ...

  6. adobe

    使用adobe acrobat pro dc可以处理pdf,自动识别,编辑pdf,将pdf导出为word.(收费可破解)

  7. 『计算机视觉』经典RCNN_其二:Faster-RCNN

    项目源码 一.Faster-RCNN简介 『cs231n』Faster_RCNN 『计算机视觉』Faster-RCNN学习_其一:目标检测及RCNN谱系 一篇讲的非常明白的文章:一文读懂Faster ...

  8. file 文件上传后缀转化小写

    1.上传的文件后缀是大写的我们做上传文件的时候考虑的比较少,所以我就想把客户上传的文件后缀统一一下,后面我解析附件的时候比较好解析.例子:我得到的文件名称:$infoFileName;$fileNam ...

  9. 在ASP.NET MVC 框架中调用 html文件及解析get请求中的参数值

    在ASP.NET MVC 框架中调用 html文件: public ActionResult Index() { using (StreamReader sr = new StreamReader(P ...

  10. Spring注解之BeanPostProcessor与InitializingBean

    /*** BeanPostProcessor 为每个bean实例化时提供个性化的修改,做些包装等*/ package org.springframework.beans.factory.config; ...