《Python基础教程》 读书笔记 第五章(下)循环语句
5.5.1while循环
x=1
while x<=100:
print x
x+=1
确保用户输入了名字:
name=""
while not name:
name=raw_input('please enter your name:')
print 'hello,%s!'%name
5.5.2for循环
while语句非常灵活。它可以用来在任何条件为真的情况下重复执行一个代码块。一般情况下这样就够用了,但是有些时候还得量体裁衣。比如要为一个集合(序列和其他可迭代对象)的每个元素都执行一个代码块。这个时候可以使用for语句:
words=['a','b','c','d']
for word in words:
print word
5.5.3循环遍历字典元素
一个简单的for语句就能循环字典的所有键,就像处理序列一样
d={'x':1,'y':2,'z':3}
for key in d:
print key,'corresponds to',d[key]
注意:字典元素的顺序通常是没有定义的。换句话说,迭代的时候,字典中的健和值都能保证被处理,但是处理顺序不确定。如果顺序很重要的话,可以将键值保存在单独的列表中,例如在迭代前进行排序。
5.5.4一些迭代工具
1.并行迭代
程序可以同时迭代两个序列。
names=['anne','beth','george','damon']
ages=[12,45,32,102]
for i in range(len(names)):
print names[1],'is',ages[i],'years old'
内建的zip函数可以用来进行并行迭代,可以把两个序列“压缩”在一起,然后返回一个元组的列表:
>>> zip(names,ages)
[('anne', 12), ('beth', 45), ('george', 32), ('damon', 102)]
循环中解包元组:
>>> for name,age in zip(names,ages): print name,'is',age,'years old' anne is 12 years old beth is 45 years old george is 32 years old damon is 102 years old
zip函数也可以作用于任意多的序列。关于它很重要的一点是zip可以应付不等长的序列:当最短的序列“用完”的时候就会停止:
>>> zip(range(5),xrange(100000000)) [(0, 0), (1, 1), (2, 2), (3, 3), (4, 4)]
2.编号迭代
有些时候想要迭代序列中的对象,同时还要获取当前对象的索引。例如,在一个字符串列表中替换所有包含’XXX’的子字符串:\
index=0 for string in strings: if 'xxx' in strings: strings[index]='[censored' index+=1
另一种方法是使用内建的enumerate函数:
3.翻转和排序迭代
两个有用的函数:reversed和sorted:它们同列表的reverse和sort (sorted和sort使用同样的参数)方法类似,但作用于任何序列或可迭代对象上,不是原地修改对象,而是返回翻转或排序后的版本:
>>> sorted([4,3,5,8,1]) [1, 3, 4, 5, 8] >>> sorted('hell,world!') ['!', ',', 'd', 'e', 'h', 'l', 'l', 'l', 'o', 'r', 'w'] >>> list(reversed('hello,world')) ['d', 'l', 'r', 'o', 'w', ',', 'o', 'l', 'l', 'e', 'h'] >>> ''.join(reversed('hello,world!')) '!dlrow,olleh'
5.5.5跳出循环
1. break
结束(跳出)循环可以使用break语句。
from math import sqrt for n in range(99,0,-1): root=sqrt(n) if root ==int(root): print n break
2. continue
continue会让当前的迭代结束,“跳”到下一轮循环的开始。它最基本的意思是“跳过剩余的循环体,但是不结束循环”。当循环体很大而且很复杂的时候,这会很有用,有些时候因为一些原因可能会跳过它—这个时候可以使用continue语句:
for x in seq:
if condition1: continue
if condition2: continue
if condition3: continue
do_something()
da_ something_ else()
do_ another_thing()
etc()
很多时候,只要使用if语句就可以了:
for x in seq:
if not (condition1 or condition2 or condition3)
do_something()
do_something_else()
do_another_thing()
etc()
3.while True/break习语
while True: word=raw_input('please enter a word:') if not word:break print 'the word was '+word
while True的部分实现了一个永远不会自己停止的循环。但是在循环内部的if语句中加入条件可以的,在条件满足时调用break语句。这样一来就可以在循环内部任何地方而不是只在开头(像普通的while循环一样)终止循环。if/break语句自然地将循环分为两部分:第1部分负责初始化(在普通的while循环中,这部分需要重复),第2部分则在循环条件为真的情况下使用第1部分内初始化好的数据。
5.5.6循环中的else子句
from math import sqrt for n in range(99,81,-1): root=sqrt(n) if root==int(root): print n break else: print "didn't find it"
5.6列表推导式——轻量级循环
列表推导式(list comprehension)是利用其他列表创建新列表(类似于数学术语中的集合推导式)的一种方法。它的工作方式类似于for循环:
>>> [x*x for x in range(10)] [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
可以增加更多for语句的部分:
>>> [(x,y)for x in range(3) for y in range(3)] [(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)
5.7三人行 :pass, del和exec
5.7.1 pass
它可以在的代码中做占位符使用。比如程序需要一个jf语句,然后进行测试,但是缺少其中一个语句块的代码,考虑下面的情况:
if name=='ralph':
print 'welcome!'
elif name=='enid':
pass
elif name=='bill':
print 'access'
5.7.2使用del删除
>>> scoundrel={'age':42,'first name':'robin','last name':'of locksley'}
>>> robin=scoundrel
>>> scoundrel
{'last name': 'of locksley', 'first name': 'robin', 'age': 42}
>>> robin
{'last name': 'of locksley', 'first name': 'robin', 'age': 42}
>>> coundrel=None
>>> robin
{'last name': 'of locksley', 'first name': 'robin', 'age': 42}
>>> robin=None
首先,robin和scoundrel都被绑定到同一个字典上。所以当设置scoundrel为None的时候,字典通过robin还是可用的。但是当我把robin也设置为None的时候,字典就“漂”在内存里面了,没有任何名字绑定到它上面。没有办法获取和使用它,所以Python解释器(以其无穷的智慧)直接删除了那个字典(这种行为被称为垃圾收集)。
>>> x=["hello","world"]
>>> y=x
>>> y[1]="python"
>>> x
['hello', 'python']
>>> del x
>>> y
['hello', 'python']
>>> x
Traceback (most recent call last):
File "<input>", line 1, in <module>
NameError: name 'x' is not defined
5.7.3 使用exec和eval执行和求值字符串
1 .exec
执行一个字符串的语句是exec:
>>> exec "print 'hello,world!'"
hello,world!
>>> from math import sqrt
>>> exec "sqrt=1"
>>> sqrt(4)
Traceback (most recent call last):
File "<input>", line 1, in <module>
TypeError: 'int' object is not callable
exec语句最有用的地方在于可以动态地创建代码字符串。如果字符串是从其他地方获得的—很有可能是用户—那么几乎不能确定其中到底包含什么代码。所以为了安全起见,可以增加一个字典,起到命名空间的作用。
可以通过增加in<scope>来实现,其中的<seope>就是起到放置代码字符串命名空间作用的字典。
>>> from math import sqrt
>>> scope={}
>>> exec "sqrt=1" in scope
>>> sqrt(4)
2.0
>>> scope['sqrt']
1
可以看到,潜在的破坏性代码并不会覆盖sqrt函数,原来的函数能正常工作,而通过exec赋值的变量sqrt只在它的作用域内有效。注意,如果需要将scope打印出来的话,会看到其中包含很多东西,因为内建的_builtins_字典自动包含所有的内建函数和值:
>>> len(scope)
2
>>> scope.keys()
['__builtins__', 'sqrt']
2.eval
eval(用于“求值”)是类似于exec的内建函数。exec语句会执行一系列Python语句,而eval会计算Python表达式(以字符串形式书写),并且返回结果值,(exec语句并不返回任何对象,因为它本身就是语句)。例如,可以使用下面的代码创建一个Python计算器:
>>> eval(raw_input("enter an arthmetric expression:"))
enter an arthmetric expression: 6+18*2
42
5.8 小结
本章的新函数
chr(n) 当传入序号n时,返回n所代表的包含一个字符的字符串,(0, n< 256)
eval(source[,globals[,locals]]) 将字符申作为表达式计算,并且返回值
enumerate(seq) 产生用于迭代的(索引,值)对
ord(c) 返回单字符字符串的int值
range([start,]stop[,step]) 创建整数的列表
reversed(seq) 产生seq中值的反向版本,用于迭代
sorted(seq[,cmp][,key][,reverse]) 返回seq中值排序后的列表
xrange([start,]stop[,step]) 创造xrange对象用于迭代
zip(seq1,_eq2.…) 创造用于并行迭代的新序列
《Python基础教程》 读书笔记 第五章(下)循环语句的更多相关文章
- SQL Server2012 T-SQL基础教程--读书笔记(1-4章)
SQL Server2012 T-SQL基础教程--读书笔记(1-4章) SqlServer T-SQL 示例数据库:点我 Chapter 01 T-SQL 查询和编程背景 1.3 创建表和定义数据的 ...
- SQL Server2012 T-SQL基础教程--读书笔记(5-7章)
SQL Server2012 T-SQL基础教程--读书笔记(5-7章) SqlServer T-SQL 示例数据库:点我 Chapter 05 表表达式 5.1 派生表 5.1.1 分配列别名 5. ...
- Python基础教程学习笔记:第一章 基础知识
Python基础教程 第二版 学习笔记 1.python的每一个语句的后面可以添加分号也可以不添加分号:在一行有多条语句的时候,必须使用分号加以区分 2.查看Python版本号,在Dos窗口中输入“p ...
- Python基础教程 读书笔记(2)第二章 列表和元组
2.1序列概览 列表和元组的主要区别在于,列表可以修改,元组则不能.也就是说如果要根据要求来添加元素,那么列表可能会更好用;而出于某些原因,序列不能修改的时候,使用元组则更为合适.使用后者的理由通常是 ...
- 《Python基础教程读书笔记》
第1章 快速构造:基础知识 1.2交互式构造器 不强制分号,一行就是一行.可以加上分号 1.4数字和表达式 加.减.乘.除.整除.求余.指数.取反(-例如-2**2,**的优先级比-大) from _ ...
- Python基础教程学习笔记:第二章 列表和元组
1.序列中元素的索引: 第一个元素索引是0,第二个是1,依次递增 最后一个元素索引是-1,倒数第二个是-2,依次递减 2.序列(Sequence)的种类: 列表(list).元组(tuple).字符串 ...
- SQL Server2012 T-SQL基础教程--读书笔记(8 - 10章)
SQL Server2012 T-SQL基础教程--读书笔记(8 - 10章) 示例数据库:点我 CHAPTER 08 数据修改 8.1 插入数据 8.1.1 INSERT VALUES 语句 8.1 ...
- 《Linux内核设计与实现》第四周读书笔记——第五章
<Linux内核设计与实现>第四周读书笔记--第五章 20135301张忻 估算学习时间:共1.5小时 读书:1.0 代码:0 作业:0 博客:0.5 实际学习时间:共2.0小时 读书:1 ...
- 《Linux内核设计与实现》读书笔记——第五章
<Linux内核设计与实现>读书笔记--第五章 标签(空格分隔): 20135321余佳源 第五章 系统调用 操作系统中,内核提供了用户进程与内核进行交互的一组接口.这些接口让应用程序受限 ...
- 《Python基础教程》 读书笔记 第五章(上)条件语句
5.1 print和import的更多信息 5.1.1使用逗号输出 打印多个表达式也是可行的,只要将它们用逗号隔开就好: >>>print'age:',42 age: 42 要同时输 ...
随机推荐
- HDU1495 非常可乐 —— BFS + 模拟
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1495 非常可乐 Time Limit: 2000/1000 MS (Java/Others) M ...
- YTU 2392: 求各位数字之和
2392: 求各位数字之和 时间限制: 1 Sec 内存限制: 128 MB 提交: 1253 解决: 292 题目描述 编写一个程序,计算任意输入的正整数的各位数字之和.(输入的位数不要超过10 ...
- Scrapy运行报错:ModuleNotFoundError: No module named 'douban.douban'
运行scrapy爬虫报错: from douban.douban.items import DoubanItem ModuleNotFoundError: No module named 'douba ...
- JQuery树形插件Dynatree的包装对象
这是JQuery Dynatree插件的包装对象,做了些改进和增强,增加了右键菜单,以及相应事件等扩展1. [代码]MagicDTree的基本使用 <SCRIPT type=text/javas ...
- codeforces 447C. DZY Loves Sequences 解题报告(446A)
题目链接:http://codeforces.com/problemset/problem/447/C 题目意思:给出 一个 包含 n 个数的序列你,从中需要找出这个序列的最长子串,满足在里面只修改其 ...
- oracle自动统计信息
在11g中,默认自动收集统计信息的时间为晚上10点(周一到周五,4个小时),早上6点(周六,周日,20个小时), select a.window_name, a.repeat_interval,a ...
- Eclipse全项目搜索指定文件&字串
在eclipse中如果希望在大量的项目中寻找指定的文件可不是一件轻松的事,还好eclipse提供了强大的搜索功能. 我们可以通过通配符或正则表达式来设定查寻条件,下面是操作示例: ctrl+h 打开搜 ...
- JAVA Synchronized (一)
<编程思想之多线程与多进程(1)——以操作系统的角度述说线程与进程>一文详细讲述了线程.进程的关系及在操作系统中的表现,这是多线程学习必须了解的基础.本文将接着讲一下Java线程同步中的一 ...
- BZOJ3990 排序
题目:www.lydsy.com/JudgeOnline/problem.php?id=3990 这题很不错. 刚开始时无从下手,想了好多$O((2^n)log(2^n))$ 的idea,但是都不行. ...
- 腾讯视频API --关闭广告推荐
官方文档:http://v.qq.com/open/doc/tvpapi2.0.pdf 使用: <script src="http://imgcache.qq.com/tencentv ...