在编写程序或者查看别人的程序时,经常会遇到列表生成式,这个使用起来并不复杂,但是非常有用,使我们的代码更加简洁灵活。很多python使用者并不太会使用它。今天,就给大家详细讲解列表生成式和生成器表达式的使用

一、列表生成式

优点:一行代码几乎可以搞定所需要的任何列表

缺点:容易着迷,不易排错,不能超过三个循环

  • 用列表推导式能构建的任何列表,用别的都可以构建,比如for循环
  • 列表推导式,最多不超过3个for循环。判断只能用一个

1. 循环模式:模板:[经过加工的i for i in 可迭代对象]

使用for循环方法

li = []
for i in range(1,4):
    li.append('还珠格格第'+str(i)+'部')

print(li)                   #['还珠格格第1部', '还珠格格第2部', '还珠格格第3部']

第二种写法

li = []
for i in range(1,4):
    li.append('还珠格格第%s部' % i)

print(li)

上面的代码,可以一行搞定。用列表推导式就可以了

li = ['还珠格格第%s部' %i for i in range(1,4)]
print(li)

li = ['还珠格格第{}部'.format(i) for i in range(1,4)]         # 上下结果相同
print(li)

例:求1~10平方结果

li = [i ** 2 for i in range(1,11)]
print(li) 
执行输出:[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

2. 筛选模式:[经过加工的i for i in 可迭代对象 if 条件 筛选] 

30以内所有能被3整除的数
l3 = [i for i in range(1,31) if i % 3 == 0]
print(l3)                                 # [3, 6, 9, 12, 15, 18, 21, 24, 27, 30]
30以内所有能被3整除的数的平方
li = [i**2 for i in range(1,31) if i % 3 == 0]
print(li)                                 # [9, 36, 81, 144, 225, 324, 441, 576, 729, 900]
找到嵌套列表中名字含有两个'e'的所有名字
names = [['Tom', 'Billy', 'Jefferson', 'Andrew', 'Wesley', 'Steven', 'Joe'],['Alice', 'Jill', 'Ana', 'Wendy', 'Jennifer', 'Sherry']]
l4 = [name for i in names for name in i if name.count('e') == 2 ]
print(l4)                                 # ['Jefferson', 'Wesley', 'Steven', 'Jennifer']

常用的是列表推导式

字典推导式

将一个字典的key和value对调

dict = {'a': 10, 'b': 34}
dict_frequency = {dict[k]: k for k in mcase}
print(dict_frequency) 
执行输出:{10: 'a', 34: 'b'}

相当于

dict = {'a': 10, 'b': 34}
dict_frequency = {}
for k in dict:
    dict_frequency[k]=dict[k]

print(dict_frequency) 
如果Key和value是一样的,不适合上面的代码

集合推导式

计算列表中每个值的平方,自带去重功能

squared = {x**2 for x in [1, -1, 2]}
print(squared)
执行输出:{1, 4}
a = {1,1,4}
print(type(a)) 
执行输出:<class 'set'>  结果是一个集合,它也是用{}表示的。

集合和字典是有区别的:

  有键值对的,是字典,比如{'k1':1,'k1':2}

  没有键值对的,是集合,比如{1,2,3,4}

二、生成器表达式

与列表推导式相同,只是将[ ]改为( )

l_obj = ('还珠格格第%s部' % i for i in range(1,4))
print(l_obj)
结果是一个生成器对象:<generator object <genexpr> at 0x000002DDBEBADE60>

取值使用__next__方法

l_obj = ('还珠格格第%s部' % i for i in range(1,4))

print(l_obj.__next__())
print(l_obj.__next__())
print(l_obj.__next__())
输出结果:
还珠格格第1部
还珠格格第2部
还珠格格第3部

列表推导式:一目了然,占内存

生成器表达式: 不便看出,节省内存。

python函数 | 列表生成式的更多相关文章

  1. python基础——列表生成式

    python基础——列表生成式 列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式. 举个例子,要生成list [1, 2, 3, 4 ...

  2. 【转】Python之列表生成式、生成器、可迭代对象与迭代器

    [转]Python之列表生成式.生成器.可迭代对象与迭代器 本节内容 语法糖的概念 列表生成式 生成器(Generator) 可迭代对象(Iterable) 迭代器(Iterator) Iterabl ...

  3. Python学习笔记(六)Python的列表生成式、生成器

    列表生成式 List Comprehensions 列表生成式是Python内置的非常简单却强大的可以用来创建list的生成式. 简单的数值范围的list可以使用一下方式生成: >>> ...

  4. python之列表生成式

    列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式. 1,比如:要生成list [1, 2, 3, 4, 5, 6, 7, 8, 9, ...

  5. Python之列表生成式、生成器、可迭代对象与迭代器

    本节内容 语法糖的概念 列表生成式 生成器(Generator) 可迭代对象(Iterable) 迭代器(Iterator) Iterable.Iterator与Generator之间的关系 一.语法 ...

  6. Python 中列表生成式和生成器

    列表生成式 即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式. 举个例子,要生成list [1,2,3,4,5,6,7,8,9,10]可以用l ...

  7. Python函数——列表推导式、生成器与迭代器

    列表推导式 产生背景 现在有个需求,看列表[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],要求你把列表里的每个值加1,你怎么实现? 第一种方法: a = [1,3,4,6,7,7,8,9 ...

  8. python 基础 列表生成式 生成器

    列表生成式 列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式 举个例子,要生成list [1, 2, 3, 4, 5, 6, 7, ...

  9. python基础----列表生成式、生成器表达式

    结论: 1.把列表解析的[]换成()得到的就是生成器表达式 2.列表解析与生成器表达式都是一种便利的编程方式,只不过生成器表达式更节省内存 3.Python不但使用迭代器协议,让for循环变得更加通用 ...

随机推荐

  1. windows下隐藏磁盘分区(转)

    在一定情况下有的人会想隐藏掉部分分区,比如双系统的情况 有两种方式 方法1: 删除盘符,适合在双系统的情况下隐藏掉另外一个系统相关的分区 请注意是删除盘符 不是删除分区 此电脑右键管理 点击磁盘管理 ...

  2. SpringBootSecurity学习(18)前后端分离版之 OAuth2.0 数据库(MyBatis)存储客户端

    使用Mybatis查询客户端信息 前面的例子使用了默认的jdbc配置来动态从数据库查询客户端信息,下面来改用更加灵活的mybatis来实现,改用mybatis,首先pom中换成mybatis的依赖: ...

  3. Mysql获取字符串中的数字函数方法和调用

    )) ) BEGIN ; ) default ''; set v_length=CHAR_LENGTH(Varstring); DO )) )) ) THEN )); END IF; ; END WH ...

  4. SQL server数据库创建代码,filegroup文件组修改,

    以下示例在 SQL Server 实例上创建了一个数据库.该数据库包括一个主数据文件.一个用户定义文件组和一个日志文件.主数据文件在主文件组中,而用户定义文件组包含两个次要数据文件.ALTER DAT ...

  5. 记vs2017编辑launchSettings.json中launchUrl错误

    当编辑launchSettings.json中launchUrl后,api访问出错,Swagger页面不能使用. 解决方法:将项目根目录下.vs文件夹删除,然后重新生成,ok

  6. Kubeadm 1.9 HA 高可用集群本地离线镜像部署【已验证】

    k8s介绍 k8s 发展速度很快,目前很多大的公司容器集群都基于该项目,如京东,腾讯,滴滴,瓜子二手车,易宝支付,北森等等. kubernetes1.9版本发布2017年12月15日,每三个月一个迭代 ...

  7. JVM故障分析系列之四:jstack生成的Thread Dump日志线程状态

    JVM故障分析系列之四:jstack生成的Thread Dump日志线程状态  2017年10月25日  Jet Ma  JavaPlatform JVM故障分析系列系列文章 JVM故障分析系列之一: ...

  8. 灰度共生矩阵(Gray-level Co-occurrence Matrix,GLCM),矩阵的特征量

    又叫做灰度共现矩阵 Prerequisites 概念 计算方式 对于精度要求高且纹理细密的纹理分布,我们取像素间距为d=1d=1,以下是方向的说明: 我们来看,matlab内置工具箱中的灰度共生矩阵的 ...

  9. CDN: trunk Repo update failed - CocoaPods

    解决方案: 1.podfile文件中添加source源:  source 'https://github.com/CocoaPods/Specs.git' 2.执行 pod repo remove t ...

  10. Eureka设计原理

    1. Eureka设计原理 1.1. 前言 目前我越来越关注技术原理层面的东西,开始考虑中间件设计背后,要考虑哪些因素,为什么要这样设计,有什么优化的地方,这次来讨论Eureka 1.2. 设计问题 ...