python-第一类对象,闭包,迭代器
# 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-第一类对象,闭包,迭代器的更多相关文章
- python 第一类对象 闭包 迭代器
########################总结########################### 1. 函数名 -> 第一类对象 函数名就是变量名. 函数可以赋值 函数可以作为集合类的 ...
- python第一类对象,闭包,迭代器
一.第一类对象 第一类对象 -> 函数名 -> 变量名 1.特征: 函数对象可以像变量一样进行赋值 还可以作为列表的元素进行使用 还可以作为返回值返回 还可 ...
- python 函数名的应用(第一类对象),闭包,迭代器
1.函数名的应用(第一类对象) 函数名的命名规范和变量是一样的 函数名其实就是变量名 可以作为列表中的元素进行储存. def func1(): pass def func2(): pass lst = ...
- 巨蟒python全栈开发-第11天 第一类对象 闭包 迭代器
一.今日主要内容总览(重点) 1.第一类对象->函数名=>变量名 (1)函数对象可以像变量一样进行赋值 (2)还可以作为列表的元素进行使用 (3)还可以作为返回值返回 (4)还可以作为参数 ...
- Python_Mix*函数名的使用以及第一类对象,闭包,迭代器,for循环的内部机制
一:函数名的应用(第一类对象) 函数名的命名规范和变量是一样的,函数名其实就是变量名, 0)函数名可以赋值给其他变量 def func(): #定义一个名为func的函数 print('my ange ...
- day11 第一类对象 闭包 迭代器
今日主要内容: 1 . 第一类对象 -->函数名--> 变量名 2. 闭包 -->函数的嵌套 3. 迭代器 --> 固定的思想 for 循环 第一类对象 : 函数对象介意向变 ...
- 完全理解 Python 迭代对象、迭代器、生成器(转)
完全理解 Python 迭代对象.迭代器.生成器 本文源自RQ作者的一篇博文,原文是Iterables vs. Iterators vs. Generators » nvie.com,俺写的这篇文章是 ...
- 完全理解 Python 迭代对象、迭代器、生成器
完全理解 Python 迭代对象.迭代器.生成器 2017/05/29 · 基础知识 · 9 评论 · 可迭代对象, 生成器, 迭代器 分享到: 原文出处: liuzhijun 本文源自RQ作者 ...
- python记录_day11 闭包 迭代器
一.第一类对象: 函数名是一个变量,可以当普通变量使用,但它又是一个特殊的变量,与括号配合可以执行函数. 函数名的运用 1.单独打印是一个内存地址 2.可以给其他变量赋值 3.可以作为容器类变量的元素 ...
- 完全理解Python迭代对象、迭代器、生成器
在了解Python的数据结构时,容器(container).可迭代对象(iterable).迭代器(iterator).生成器(generator).列表/集合/字典推导式(list,set,dict ...
随机推荐
- Lambda语法篇
函数式接口 函数式接口(functional interface 也叫功能性接口,其实是同一个东西).简单来说,函数式接口是只包含一个方法的接口. Lambda语法 包含三个部分 一个括号内用逗号分隔 ...
- centos如何查看linux内核,版本号
[root@localhost ~]# uname -a Linux localhost.localdomain -.el7.x86_64 # SMP Thu Nov :: UTC x86_64 x8 ...
- 解决ios下的微信页面背景音乐无法自动播放问题
在做各种html5场景页面的时候,插入背景音乐是一个很普遍的需求,我们都知道,ios下的safari是无法自动播放音乐的,以至于现在行程一种认知,ios是没有办法自动播放媒体资源的,这个认知其实是错误 ...
- pycharm设置连接github
pycharm与guthub连起来,推送代码会方便一些 教程很多,转发一个:https://www.cnblogs.com/feixuelove1009/p/5955332.html
- JS中如何生成全局变量
JS中如何生成全局变量 一.总结 一句话总结:在函数内部,一般用var声明的为局部变量,没用var声明的一般为全局变量 在函数内没用var声明的一般为全局变量 1.js中的函数中的this指向的是谁? ...
- Redisson实现分布式锁(一)
为什么要使用分布式锁? 单机情况下,多线程同时访问并改变临界资源(可变共享变量),将会使得这个变量不可预知,所以我们引入了同步(lock—synchronized).但在分布式场景下(多机部署),业务 ...
- 雷林鹏分享:jQuery EasyUI 插件
jQuery EasyUI 插件 jQuery EasyUI 提供了用于创建跨浏览器网页的完整的组件集合,包括功能强大的 datagrid(数据网格).treegrid(树形表格). panel(面板 ...
- spring ----> 搭建spring+springmvc+mybatis出现的几个问题
环境: idea ce 2018.1+maven3.5.3+mysql8.0.11+jdk1.8 spring4.3.7+spring mvc4.3.7+mybatis3.4.1+tomcat7.0. ...
- Using the G711 standard
Using the G711 standard Marc Sweetgall, 28 Jul 2006 4.74 (27 votes) 1 2 ...
- LeetCode--292--Nim游戏
问题描述: 你和你的朋友,两个人一起玩 Nim游戏:桌子上有一堆石头,每次你们轮流拿掉 1 - 3 块石头. 拿掉最后一块石头的人就是获胜者.你作为先手. 你们是聪明人,每一步都是最优解. 编写一个函 ...