Python(五)之迭代器和列表解析

Python迭代器和列表解析

  • 迭代器

例如:

In [1]: l1 = [1,2,3,4,5]

dir(i1)可以看到内置方法‘__iter__‘

生成一个迭代器:

l1.__iter__,或i2 = iter(l1)

  • 列表解析

列表解析:根据已有列表,高效生成新列表的方式

列表交叉生产元素为元组的列表:

列表解析扩展:

上述列表解析直接生成列表,如果列表过大,会占用过多内存,那么可以使用生成器返回一个生成器对象,如下解释:列表解析和生成器表达式关系类似于range和xrange的关系。

例如:

rang(1,10,2)引用索引本身

enumerate 及引用所用又引用元素本身

时间: 2024-10-04 15:27:36

Python(五)之迭代器和列表解析的相关文章

python_day04 函数嵌套 名称空间和作用域 闭包 装饰器 迭代器 生成器 列表解析 三元表达式 生成器表达式

本节课重要知识点内容如下: 函数嵌套 名称空间和作用域 闭包 装饰器 迭代器 生成器 列表解析 三元表达式 生成器表达式 1.函数嵌套 函数的嵌套调用:在调用一个函数的过程中,又调用了其他函数函数的嵌套定义:在一个函数的内部,又定义另外一个函数 def bar(): print('from nbar')def foo(): print('from foo') bar()foo()def max2(x,y): if x > y: return x else: return ydef max4(a,

Python内置容器(2)——字典,迭代器,列表解析

1.迭代器 iterator iter 函数,构造集合. next 方法依次返回迭代器的值 In [42]: li Out[42]: [1, 2, 3, 4, 5] In [43]: it = iter(li) In [44]: it.next() Out[44]: 1 In [45]: it.next() Out[45]: 2 当所有的元素都返回完的时候,会抛出一个StopIterator 的异常. list,tuple,set 都属于集合. for 语句,当将一个列表传递给for 语句的时候

Python自动化运维之7、格式化输出、生成器、迭代器、列表解析、迭代器表达式

Python格式化输出: Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] (1)百分号格式化 %[(name)][flags][width][.precision]typecode .... (name) 可选,用于选择指定的key flags 可选,可供选择的值有: + 右对齐:正数前加正好,负数前加负号: - 左对齐:正数前无符号,负数前加负号: 空

3、Python迭代器、列表解析及生成器(0530)

回顾: 1.动态语言 sys.getrefcount()    //查看对象的引用计数 增加对象的引用计数场景 对象创建时:以赋值的方式,创建变量名的同时就会创建变量 将对象添加进容器时:类似list.append() 当对象被当作参数传递给函数时 多重目标赋值时:s1 = s2 = s3 = 'abc' 为对象创建另外的变量名 减少引用计数 引用此对象的某变量名被显示销毁:del x 引用此对象的某变量名重新赋值 从容器中移除对象时,类似list.pop() 容器本身被销毁 2.if if b

Python基础-----三元表达式、列表解析、生成器表达式

三元表达式: 变量 = 值1 if 条件为真 else 值2 类似于: res = '对了' if 1 > 2 else '错了' print(res) >>> '错了' 普通表示: if 1 > 2: print('对了') else: print('错了') 列表解析: 假如要生成0-9共10个数字,存放在列表中 类似于: l = [i for i in range(10)] print(l) >>> [0, 1, 2, 3, 4, 5, 6, 7, 8

《转》python学习(12)-列表解析

一.列表解析 列表解析来自函数式编程语言(haskell),语法如下: [expr for iter_var in iterable] [expr for iter_var in iterable if cond_expr] 第一种语法:首先迭代iterable里所有内容,每一次迭代,都把iterable里相应内容放到iter_var中,再在表达式中应用该iter_var的内容,最后用表达式的计算值生成一个列表. 第二种语法:加入了判断语句,只有满足条件的内容才把iterable里相应内容放到i

函数---迭代器&生成器&列表解析&三元表达式

可迭代对象:obj.__iter__ 迭代器:iter1=obj.__iter() 1iter1.__next__ 2iter2.__next__ 迭代器: 优点:不依赖索引 惰性计算,节省内存 缺点: 不如按照索引的取值方便 一次性,只能往后取,不能回退 迭代器的应用: 提供了一种不依赖索引的统一的迭代方法 惰性计算,比如取文件的每一行 判断可是否是可迭代对象和迭代器 from collections import Iterable, Iterator # 导入模块功能 isinstance(

Python filter,map,lambda,reduce,列表解析

filter用法 filter(func,seq) 将seq的元素逐一代入func,通过func的返回值来判断是保留还是过滤 1 >>> def foo(x): 2 return x>3 3 4 >>> filter(foo,range(6)) 5 [4, 5] >>> filter(lambda x:x>3,range(6))[4, 5] 6 #注意只需要写函数名,不带参数 map用法map(func/lambda,seq) 通过函数对队

python 点滴记录10:列表解析

列表解析语法格式: 第一种格式: [expr for iter_var in iterable] 迭代iterable里的每一个元素,每迭代一个,就把一个元素放入iter_var.然后在表达式(expr)中应用iter_var中的内容. eg: [random.randint(0,101) for i in range(10)]  #随机抽取0到100之间的10个数字 第二种格式: [expr for iter_var in iterable if cond_expr] 只有符合if条件的元素才