今天就来介绍一下内置函数和迭代器 、生成器相关的知识

一、内置函数:就是Python为我们提供的直接可以使用的函数。

  1. 简单介绍几个自己认为比较重要的
  2. 1.#1.eval函数:(可以把文件中每行中的数据类型提取出来(之前是字符串类型))
  3. a = "{'a':23,'b':43,'book':'english'}"
  4. print(eval(a))
  5.  
  6. 2.#2.hash(可以hash的数据类型是不可变数据类型)
  7. a = 'alex'
  8. b = hash(a)
  9. print(b)
  10.  
  11. 3.#zip 函数(组成一一对应的元组)(如果外面不加一个lis那没得到的就是一个zip对象)
  12. print(list(zip(('a','b','c'),(1,2,3))))
  13. print(list(zip(('a','b','c'),(1,2,3,4))))
  14. print(list(zip(('a','b','c','d'),(1,2,3))))
  15.  
  16. p = {'name':'alex','age':23,'gender':'male'}
  17. print(list(zip(p.keys(),p.values())))
  18. 输出结果为:
  19. [('a', 1), ('b', 2), ('c', 3)]
  20. [('a', 1), ('b', 2), ('c', 3)]
  21. [('a', 1), ('b', 2), ('c', 3)]
  22. [('name', 'alex'), ('age', 23), ('gender', 'male')]
  23.  
  24. # #max 和 min 函数
  25. # l = [
  26. # (5,'e'),
  27. # (2,'b'),
  28. # (3,'c'),
  29. # (6,'d')
  30. # ]
  31. #
  32. # print(list(max(l)))
  33. # #max 函数的两点说明:
  34. # #1.max处理的是可以迭代的对象,相当于for循环取出每个元素进行比较,不同数据类型之间不可以比较
  35. # #2.每个元素之间的比较是从每个元素的第一个位置依次比较,如果此位置可以区分出大小,后面就不需要比较了,直接得出这两个元素的大小
  36. #
  37. #
  38. # #sorted函数的使用(都是按照从小到大的顺序进行排列)
  39. #
  40. # name_dict ={
  41. # 'yuanhao':80,
  42. # 'alex':99,
  43. # 'wupeiqi':700
  44. # }
  45. # print(sorted(name_dict))
  46. # print(sorted(name_dict,key = lambda key:name_dict[key]))
  47. #

内置函数的补充:

  1. 1.对数据的进制转化
  2. a = hex(12)#1016
  3. b = bin(12) #10转 2
  4. c = oct(12) #10 转8
  5. print(a)
  6. print(b)
  7. print(c)
  8.  
  9. #输出结果为:
  10. 0xc
  11. 0b1100
  12. 0o14
  13.  
  14. 2.数字转字母,字母转数字
  15. a = ord('A')
  16. b = chr(99)
  17. print(a,b)
  18. 输出结果:65 c
  19.  
  20. 3.divmod 取余函数(用在做网页的文章分页)
  21. c = divmod(10,3)
  22. print(c)
  23. 输出结果:(3, 1) #3余数为1
  24.  
  25. 4.求次方函数
  26. d = pow(2,3)
  27. e = pow(2,3,4)
  28. print(d,e) #d:2的3次方;e:2的3次方对4取余
  29.  
  30. 5.reversed函数取翻转
  31.  
  32. 6.round() #四舍五入函数

二、迭代器协议与生成器

1.迭代器协议:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前退)

2.可迭代对象:实现了迭代器协议的对象(如何实现:对象内部定义一个__iter__()方法)

3.协议是一种约定,可迭代对象实现了迭代器协议,python的内部工具(如for循环,sum,min,max函数等)使用迭代器协议访问对象。

三、Python中强大的for 循环机制

for循环的本质:循环所有对象,全都是使用迭代器协议。

很多人会想,for循环的本质就是遵循迭代器协议去访问对象,那么for循环的对象肯定都是迭代器了啊,没错,那既然这样,for循环可以遍历(字符串,列表,元组,字         典,集合,文件对象),那这些类型的数据肯定都是可迭代对象啊?但是,我他妈的为什么定义一个列表l=[1,2,3,4]没有l.next()方法,打脸么。

(字符串,列表,元组,字典,集合,文件对象)这些都不是可迭代对象,只不过在for循环式,调用了他们内部的__iter__方法,把他们变成了可迭代对象

然后for循环调用可迭代对象的__next__方法去取值,而且for循环会捕捉StopIteration异常,以终止迭代

  1. #2.for循环内部实现的机制
  2.  
  3. l = [1,2,3,4]
  4.  
  5. for i in l:#(i_1 = l._iter__() / i_l.__next__())
  6. print(i)
  7.  
  8. iter_l = l.__iter__()#遵循迭代器协议,生成可以迭代的对象
  9. print(iter_l.__next__())
  10. print(iter_l.__next__())
  11. print(iter_l.__next__())
  12.  
  13. #通过while循环实现遍历列表
  14. l = [1,3,5]
  15. index = 0
  16. while index <len(l):
  17. print(l[index])
  18. index +=1
  19.  
  20. #集合中使用迭代器
  21. s = {1,2,3}
  22. iter_s = s.__iter__()
  23. print(iter_s)
  24. print(iter_s.__next__())
  25. print(iter_s.__next__())
  26. print(iter_s.__next__())
  27.  
  28. #字典中使用迭代器
  29. d = {'alex':44,'egon':56}
  30. iter_d = d.__iter__()#默认迭代的是key
  31. print(iter_d.__next__())
  32. print(iter_d.__next__())
  33.  
  34. #文件中使用迭代器
  35. with open('test','r+') as f:
  36.  
  37. iter_f = f.__iter__()
  38. print(iter_f.__next__(),end = '')#通过end参数解决了不是以默认的方式换行的问题
  39. print(iter_f.__next__(),end = '')
  40. print(iter_f.__next__(),end = '')
  41.  
  42. #文件关闭后对文件的操作就会报错
  43. f=open('test','r')
  44. iter_f = f.__iter__()
  45. print(iter_f.__next__())
  46. #f.close()
  47. print(iter_f.__next__())
  48.  
  49. '''

四、生成器

可以理解为一种数据类型,这种数据类型自动实现了迭代器协议(其他的数据类型需要调用自己内置的__iter__方法),所以生成器就是可迭代对象

生成器分类及在python中的表现形式:(Python有两种不同的方式提供生成器)

    1.生成器函数:常规函数定义,但是,使用yield语句而不是return语句返回结果。yield语句一次返回一个结果,在每个结果中间,挂起函数的状态,以便下次重它离开的地方继续执行

    2.生成器表达式:类似于列表推导,但是,生成器返回按需产生结果的一个对象,而不是一次构建一个结果列表

为何使用生成器之生成器的优点

Python使用生成器对延迟操作提供了支持。所谓延迟操作,是指在需要的时候才产生结果,而不是立即产生结果。这也是生成器的主要好处。

生成器小结:

1.是可迭代对象

2.实现了延迟计算,省内存啊

3.生成器本质和其他的数据类型一样,都是实现了迭代器协议,只不过生成器附加了一个延迟计算省内存的好处,其余的可迭代对象可没有这点好处,记住喽!!!

  1. def test():
  2. yield 1
  3. yield 2
  4. yield 3
  5. g=test()#写完此句才是生成器对象
  6. print('来自函数',g)#来自函数 <generator object test at 0x02170CC0>
  7. # print(g.__next__())#生成器内部有next方法,直接调用就ok
  8. # print(g.__next__())
  9. # print(g.__next__())
  10.  
  11. #三元表达式
  12. name='alex'
  13. name='linhaifeng'
  14. res='SB' if name == 'alex' else '帅哥'
  15. print(res)
  16.  
  17. #列表解析
  18. #通过for循环的形式实现原理
  19. egg_list=[]
  20. for i in range(10):
  21. egg_list.append('鸡蛋%s' %i)
  22. print(egg_list)
  23. #列表解析的表达形式
  24. l=['鸡蛋%s' %i for i in range(10)]#%后面相当于一个要传给前面的一个参数
  25. l1=['鸡蛋%s' %i for i in range(10) if i > 5 ] #列表解析中的三元表达式形式
  26. # # l1=['鸡蛋%s' %i for i in range(10) if i > 5 else i] #没有四元表达式
  27. # l2=['鸡蛋%s' %i for i in range(10) if i < 5] #没有四元表达式
  28.  
  29. print(l)
  30. print(l1)
  31. # print(l2)
  32.  
  33. #生成器表达式
  34. laomuji=('鸡蛋%s' %i for i in range(10)) #生成器表达式,就是把列表解析中的[]换成()
  35. print(laomuji)
  36. print(laomuji.__next__())
  37. print(laomuji.__next__())
  38. print(next(laomuji))
  39. print(next(laomuji))
  40. print(next(laomuji))
  41. print(next(laomuji))
  42. print(next(laomuji))
  43. print(next(laomuji))
  44. print(next(laomuji))
  45. print(next(laomuji))
  46. # print(next(laomuji)) 报错: StopIteration
  47.  
  48. '''
  49. '''
  50. #生成器函数
  51. import time
  52. def test():
  53. print('开始生孩子啦。。。。。。')
  54. print('开始生孩子啦。。。。。。')
  55. print('开始生孩子啦。。。。。。')
  56. yield '我' #yield 相当于return 作用就是做返回值用
  57. time.sleep(3)
  58. print('开始生儿子啦')
  59. yield '儿子'
  60.  
  61. time.sleep(3)
  62. print('开始生孙子啦')
  63. yield '孙子'
  64.  
  65. res=test()#执行此句只是在定义一个生成器对象
  66. print(res)#<generator object test at 0x00700D20>
  67. print(res.__next__()) #test()
  68. print(res.__next__()) #test()
  69. print(res.__next__()) #test()

实现生产者和消费者模型的例子:

  1. #实例:实现生产者消费者模型
  2. #通过生成器实现协程并行运算
  3. import time
  4. def consumer(name):
  5. print("%s 准备吃包子啦!" %name)
  6. while True:
  7. baozi = yield 1 #yield 的第二个作用就是接受send传过来的参数赋值给包子变量
  8.  
  9. print("包子[%s]来了,被[%s]吃了!" %(baozi,name))
  10.  
  11. def producer(name):
  12. c = consumer('A')
  13. c2 = consumer('B')
  14. print( c.__next__())
  15. print(c2.__next__())
  16. print("老子开始准备做包子啦!")
  17. for i in range(10):
  18. time.sleep(1)
  19. print("做了2个包子!")
  20. c.send(i)#send 函数实现了向yield函数传递参数的作用
  21. c2.send(i)
  22.  
  23. producer("alex")

生成器中send()方法的应用

  1. #send 参数的实例演示
  2. #yield 相当于return 控制的是函数的返回值
  3. #x = yield 的另外一个特性就是接受send传过来的值并且把值付给x
  4.  
  5. def test():
  6. print('开始啦')
  7. first = yield 1 #return 1 first = None
  8. print('第一次',first)
  9. yield 2
  10. print('第二次')
  11.  
  12. t = test()
  13. res = t.__next__()# -->next()
  14. print(res) #res取得是yield的返回值
  15.  
  16. t.send(None)
  17.  
  18. 计算结果为:
  19. 开始啦
  20. 1
  21. 第一次 None

生成器总结:

综上已经对生成器有了一定的认识,下面我们以生成器函数为例进行总结

  • 语法上和函数类似:生成器函数和常规函数几乎是一样的。它们都是使用def语句进行定义,差别在于,生成器使用yield语句返回一个值,而常规函数使用return语句返回一个值
  • 自动实现迭代器协议:对于生成器,Python会自动实现迭代器协议,以便应用到迭代背景中(如for循环,sum函数)。由于生成器自动实现了迭代器协议,所以,我们可以调用它的next方法,并且,在没有值可以返回的时候,生成器自动产生StopIteration异常
  • 状态挂起:生成器使用yield语句返回一个值。yield语句挂起该生成器函数的状态,保留足够的信息,以便之后从它离开的地方继续执行

优点一:生成器的好处是延迟计算,一次返回一个结果。也就是说,它不会一次生成所有的结果,这对于大数据量处理,将会非常有用。

优点二:生成器还能有效提高代码可读性

注:此处的总结来源于:http://www.cnblogs.com/linhaifeng/articles/6133014.html

Python 基础 内置函数 迭代器与生成器的更多相关文章

  1. python基础——内置函数

    python基础--内置函数  一.内置函数(python3.x) 内置参数详解官方文档: https://docs.python.org/3/library/functions.html?highl ...

  2. python基础-内置函数详解

    一.内置函数(python3.x) 内置参数详解官方文档: https://docs.python.org/3/library/functions.html?highlight=built#ascii ...

  3. python基础----内置函数----匿名函数(lambda)

    Python3版本所有的内置函数: 1. abs() 获取绝对值 >>> abs(-) >>> abs() >>> abs() >>& ...

  4. Python基础-内置函数、模块、函数、json

    内置函数 1.id()返回对象的内存地址: 2. type() 返回对象类型:   3.print()打印输出: 4. input()接受一个标准输入数据,返回为string类型: 5. list() ...

  5. Python菜鸟之路:Python基础-内置函数补充

    常用内置函数及用法: 1. callable() def callable(i_e_, some_kind_of_function): # real signature unknown; restor ...

  6. Python基础-内置函数总结

    内置函数 int('123') float() string() tuple() set() dict(name='zdd',age=18) type()#查看类型 len()#看长度,其实是元素的个 ...

  7. Python基础—内置函数(Day14)

    一.内置函数 1.***eval:执行字符串类型的代码,并返回最终结果(去掉括号里面是什么就返回什么). print(eval('3+4')) #7 ret = eval('{"name&q ...

  8. python基础--内置函数map

    num_1=[1,2,10,5,3,7] # num_2=[] # for i in num_1: # num_2.append(i**2) # print(num_2) # def map_test ...

  9. python 基础 内置函数

    内置参数 print(all([5,-1,5])) # 非0都是真 true print(all([0,-1,5])) # false print(any([1,0,5])) # 有一个数据为真,就为 ...

随机推荐

  1. 超实用的mysql分库分表策略,轻松解决亿级数据问题

    一.分库分表的背景 在数据爆炸的年代,单表数据达到千万级别,甚至过亿的量,都是很常见的情景.这时候再对数据库进行操作就是非常吃力的事情了,select个半天都出不来数据,这时候业务已经难以维系.不得已 ...

  2. JavaScript中For循环以及For循环嵌套实例

    JavaScript中For循环实例 1.打印出所有的 "水仙花数 ",所谓 "水仙花数 "是指一个三位数,其各位数字立方和等于该数本身. 例如:153是一个 ...

  3. 使用Spring 或Spring Boot实现读写分离( MySQL实现主从复制)

    http://blog.csdn.net/jack85986370/article/details/51559232 http://blog.csdn.net/neosmith/article/det ...

  4. opencv::Mat属性

    OpenCV支持JPG.PNG.TIFF等常见格式图像文件加载 加载图像 Mat imread( const String& filename, int flags = IMREAD_COLO ...

  5. 《Java并发编程实战》读书笔记-第5章 基础构建模块

    同步容器类 同步容器类实现线程安全的方式:将所有状态封装起来,对每个公有方法使用同步,使得每一次只有一个线程可以访问.同步容器类包含:Vector.Hashtable.Collections.sync ...

  6. php是做前端的吗?

    php是做前端的吗 不是,php是后台脚本语言,由服务器执行. PHP即“超文本预处理器”,是一种通用开源脚本语言.PHP是在服务器端执行的脚本语言,与C语言类似,是常用的网站编程语言.PHP独特的语 ...

  7. 微信小程序单选/多选框样式重新

    /* 重写 checkbox 样式 */ /* 未选中的 背景样式 */ checkbox .wx-checkbox-input{ border-radius: 50%;/* 圆角 */ width: ...

  8. ElasticSearch Bulk API

    做一个简单的记录,以便自己后续查找 一.环境要求 ElasticSearch 7.3.0 Kibana 7.3.0 二.详情 ElasticSearch 的 Bulk API 可以批量进行索引或者删除 ...

  9. 如果有人问你 MySql 怎么存取 Emoji,把这篇文章扔给他

    01.前言 Emoji 在我们生活中真的是越来越常见了,几乎每次发消息的时候不带个 Emoji,总觉得少了点什么,似乎干巴巴的文字已经无法承载我们丰富的感情了.对于我们开发者来说,如何将 Emoji ...

  10. WebShell代码分析溯源(一)

    WebShell代码分析溯源(一) 一.一句话变形马样本 <?php $_GET['POST']($_POST['GET']);?> 二.代码分析 1.调整代码格式 <?php $_ ...