【快乐Python之一】List Comprehensions 和 Generator Expressions

本文深入解析了Python中ListComprehensions和GeneratorExpressions的使用方法,包括两者的基本概念、语法差异及应用场景。重点展示了如何利用这两种方法高效地构造列表,并通过实例对比了ListComprehensions和GeneratorExpressions的优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

List Comprehensions 和 Generator Expressions

List Comprehensions和Generator Expressions是Python里十分常用的在复杂条件下构造列表的两种方法。那么我们怎么使用这两种方法呢?下面我将我的理解写出来供大家参考。下面的文章中listcomps 将代表 List Comprehensions,而 genexps 将代表 Generator Expressions。 我们先来看listcomps。一般来说,如果我们要通过某些条件构造一个新的list,很容易想到用最普通的方法:

old_list =['a','b','c', 1, 2,3]
new_list = list()
for i in old_list:
      if isinstance(i, basestring):
          new_list.append(i)
而如果我们采用listcomps的方法应该成下面这样:

new_list =[i for i in old_list if isinstance(i, basestring)]
>>> new_list
['a', 'b', 'c']
 
例如生成一个3的倍数的列表
>>>[n for n in xrange(3,30) if n% 3== 0]
[3, 6, 9, 12, 15, 18, 21, 24, 27] 

 下面我们再来看genexps,同样我们要求1 + 2 + 3... + 100, 我们能想到最普通的方法是:

total = 0
for n in xrange(1,101):
    total += n
如果我们有listcomps,那么应该是:
>>> total= 0
>>> total= sum([n for n in xrange(1,101)])
>>>print total
5050
而下面用的则是genexps,

>>> total= 0
>>> total= sum(n for n in xrange(1,101))
>>>print total
5050 

我们可以看出,listcomps和genexps    是很相似的,但是他们确实是不一样的。他们在语法(syntax)上的不同是listcomps要求用中括号[]括起来,而genexps则没有。虽然genexps有时必须用小括号()括起来,但是最好是总是用小括号将他们括起来。它们本质的区别(semantics上的)是listcomps会一次计算出整个结果列表;genexps则是一次计算一个单个值(列表元素)。


那么我们怎么来使用这两种形式呢?
1. 当被生成(计算后)的列表就是最终想要的列表时用listcomps。
2. 当被生成(计算后)的列表不是最终想要的列表而是一个中间的列表时用genexps。
现在我们应该可以很自由的运用listcomps和genexps了吧。
资源下载链接为: https://pan.quark.cn/s/9e7ef05254f8 起点中文网是广受欢迎的网络文学平台,为读者提供了海量的网络小说资源。其源码常被用于学习网页设计与开发,尤其是对准备参加网页设计大赛的选手来说,是一个极具价值的参考实践项目。在HTML方面,起点中文网源码涉及以下关键知识点: HTML结构:通过<html>、<head>、<body>等标签构建完整的网页框架,了解网页的基本架构。 标题标签:使用<h1>至<h6>定义不同级别的标题,明确页面的层次结构。 段落与换行:借助<p>标签创建段落,通过<br>实现强制换行。 链接:利用<a>标签创建超链接,掌握href属性的用法,包括内部链接外部链接。 图像:通过<img>标签插入图片,理解srcalt属性的作用。 列表:掌握无序列表<ul>、有序列表<ol>及列表项<li>的用法。 表格:使用<table>、<tr>、<th>、<td>创建表格,了解表格的基本结构及样式控制。 布局元素:使用<div>标签划分内容区域,实现页面布局。 响应式设计:可能涉及媒体查询@media,实现不同设备屏幕尺寸下的页面适配。 HTML5新特性:包括<header>、<footer>、<nav>等语义化标签,以及<audio>、<video>等多媒体元素。 除了HTML,源码还可能包含CSS的运用,例如: 选择器:熟悉类选择器、ID选择器、元素选择器及组合选择器的应用。 盒模型:理解边距、内边距、边框内容区域对元素尺寸的影响。 布局样式:掌握浮动布局、定位(relative、absolute、fixed)、Flexbox或Grid布局等。 颜色背景:通过颜色值设置文本背景色,以及背景图片的设置。 字体文本样式:调整字体、字号、行高、字间距,以及文本对齐方式。 响应式样式:利用媒体查询针对不同设备调整
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值