三、python高级特性(切片、迭代、列表生成器、生成器)
1.python高级特性
1.1切片
list列表 L=['Mli','add','sal','saoo','Lkkl']
L[0:3] #即为['Mli','add','sal'] 从索引0开始,到索引3结束,但不包括3
L[:3]等价于 L[0:3]
L[-2:] #即为 ['saoo','Lkkl'] 最后一个元素的索引为-1
L[-2:-1] #即为['Lkkl']
L=range(100) #则L[1:6:2]为 每个两个元素取一个数 所以输出为[2,4]
tuple也可以用切片操作,只是切片不可变,操作以后还是切片 例如L=(1,2,3,4) 则L[0:3]输出结果为(1,2,3)
字符串也可以用切片,例如 m='sajlkdjsalkjd' 则m[0:3] 输出'saj'
1.2迭代
如果定义一个list或tuple,可以用for循环遍历,称之为迭代
对于dict类型,也可以运用迭代,只不过输出key值
例如:
dict={'lk':'','klk':'','kkd':''}
for n in dict:
print n
结果输出
kkd
lk
klk
要想输出value值只需
dict={'lk':'','klk':'','kkd':''}
for n in dict.itervalues():
print n
同样如果想要输出 key-value的值(两个都输出),需要将代码改为 for n in dict.iteritems() #此时n为一个tuple类型
for key,v in dict.ie=ieritems()
1.3列表生成式
顾名思义 list生成式
[x*x for x in range(3)] #输出结果为[0,1,4]
[x*x for x in range(3) fi x%2==0] #输出结果为[0,4]
[m+n for m in 'ABC' for n in 'abc'] #输出结果为['Aa', 'Ab', 'Ac', 'Ba', 'Bb', 'Bc', 'Ca', 'Cb', 'Cc'](全排列)
L=['ABC','DEF','GHI'] [s.lower() for s in L] #将L中的大写字母改为小写
1.4生成器(generator)
列表生成器工作时,必须建立一个列表list,但是list的内存有限制,不可能无限大,为了弥补这一不足,生成器自然而然诞生,生成器是在不断循环的过程中推算出后面的结果,而不需要建立一个完整的list列表,所以不会占用那么多内存
生成器有很多种产生的方法,其一就是将列表生成式的[]换位()
即:g=(x*x for x in range(5)) 输出时只能用g.next()输出
即g.next() #输出0
g.next() #输出1
g.next() #输出2
g.next() #输出3
g.next() #输出4
g.next() #输出StopIteration
亦可用循环输出,即:
for n in g
print n
法二 用yield
例如斐波拉契数列 (每个数都是前两个数的和)例1,1,2,3,5,8,13.....
一般的函数定义为
def fib(max):
a,b,n=0,1,0
if n<max:
a,b,n=b,a+b,n+1
print a
如果用生成器修改函数,则只需把print改为yield
def fib(max):
a,b,n=0,1,0
if n<max:
a,b,n=b,a+b,n+1
yield a
调用时 for n in fib(6):
print n
或者 o=fib(5)
o.next() 进行输出
fib不是普通的函数,而是generator,在执行过程中,遇到yield就中断,下次继续执行,我们在循环过程中不断调用yield,就会不断中断。当然要给循环设置一个条件来退出循环,不然就会产生一个无限数列出来。
三、python高级特性(切片、迭代、列表生成器、生成器)的更多相关文章
- Python 高级特性介绍 - 迭代的99种姿势 与协程
Python 高级特性介绍 - 迭代的99种姿势 与协程 引言 写这个笔记记录一下一点点收获 测试环境版本: Python 3.7.4 (default, Sep 28 2019, 16:39:19) ...
- python高级特性:切片/迭代/列表生成式/生成器
廖雪峰老师的教程上学来的,地址:python高级特性 下面以几个具体示例演示用法: 一.切片 1.1 利用切片实现trim def trim(s): while s[:1] == " &qu ...
- Python高级特性(切片,迭代,列表生成式,生成器,迭代器)
掌握了Python的数据类型.语句和函数,基本上就可以编写出很多有用的程序了. 比如构造一个1, 3, 5, 7, ..., 99的列表,可以通过循环实现: L = [] n = 1 while n ...
- Python学习 Day 4 函数 切片 迭代 列表生成式 生成器
定义函数 def my_abs(x):#求绝对值的my_abs函数 if x >= 0: return x else: return –x def nop():#空函数 pass#占位符 参数检 ...
- 【转】Python高级特性——切片(Slice)
摘录廖雪峰网站 定义一个list: 1 L = ['haha','xixi','hehe','heihei','gaga'] 取其前三个元素: >>> L[0],L[1],L[2] ...
- Python高级特性——切片(Slice)
摘录廖雪峰网站 定义一个list: L = ['haha','xixi','hehe','heihei','gaga'] 取其前三个元素: >>> L[0],L[1],L[2] (' ...
- Day7 python高级特性-- 切片 Slice
先举一个例子,取list或tuple中的某几个元素: 1.取 ['a','b','c','d','e','f'] 第1.2.5.6个元素: >>> a = [' ...
- Python高级特性:迭代
迭代的目的是实现遍历出一个可迭代对象的元素,即for循环 基本语法 : for ... in ... 首先只有可迭代对象才可以迭代,判断一个对象是不是可以迭代的方法如下: >>> f ...
- Python高级特性(1):Iterators、Generators和itertools(转)
译文:Python高级特性(1):Iterators.Generators和itertools [译注]:作为一门动态脚本语言,Python 对编程初学者而言很友好,丰富的第三方库能够给使用者带来很大 ...
随机推荐
- [前端]利用a标签获取url里所需的内容
function parseURL(url) { var a = document.createElement('a'); a.href = url; return { source: url, pr ...
- org.hibernate.PersistentObjectException: detached entity passed to persist异常
再用jpa+spring+struts2开发的是时候遇到一个问题(采用了注解的方式,xml配置的道理是一样的),当我在注册用户的时候,注册第一个用户没有问题,但注册第二个用户开始就会抛出一个异常: j ...
- linux下的共享库(动态库)和静态库
1.什么是库在windows平台和linux平台下都大量存在着库.本质上来说库是一种可执行代码的二进制形式,可以被操作系统载入内存执行.由于windows和linux的本质不同,因此二者库的二进制是不 ...
- STL容器的效率比较
1.介绍 顺序存储容器 : string.vector.list.deque 关联存储容器:map底层采用的是树型结构,多数使用平衡二叉树实现,查找某一值是常数时间,遍历起来效果也不错, 只是每次插入 ...
- Ubuntu链接ubuntu服务器
以前在windows下用ssh工具putty连接 linux服务器, 很简单,在linux下要连接linux的服务器, 找了下,果然putty在linux中也行1,sudo apt-get insta ...
- NDK(15)在ndk代码中注册和注销native函数
转自: http://www.cnblogs.com/canphp/archive/2012/11/13/2768937.html C和C++注册native函数的方式大致上相同,下面给出具体的代码 ...
- Android权限安全(8)ContentProvider基于URI的安全
一.provider可以通过binder得到客户的uid,然后进程权限检查. 二,provider临时权限 场景: Email的内容在provider中提供,Email的客户端可读基其内容,现在一封 ...
- spring事务传播机制实例讲解
http://kingj.iteye.com/blog/1680350 spring事务传播机制实例讲解 博客分类: spring java历险 天温习spring的事务处理机制,总结 ...
- eclipse教程
http://www.eclipse.org/downloads/eclipse-packages/http://wiki.eclipse.org/Eclipse_Articles,_Tutorial ...
- 【转载】Morris遍历二叉树 & BST(二叉搜索树) Traverse & 空间O(1) 时间O(n)
因为做一道Leetcode的题目(前面博客有:link),需要用Space O(1)空间复杂度来中序遍历树, 看了Discuss,也上网搜了一下,发现空间O(1)可以用 Morris遍历的方法.方法介 ...