#coding=utf-8'''Created on 2013年11月24日@author: '''#第一种迭代方法strings = ['my','name','is','xiao','ming','his','name','is','xiao','li']for string in strings: if 'name' in string: index = strings.index(string) strings[index] = '###'print strings#第二种迭代方法strings = ['my','name','is','xiao','ming','his','name','is','xiao','li']index = 0 for string in strings: if 'name' in string: strings[index] = "***" index += 1print strings#第三种迭代的方式strings = ['my','name','is','xiao','ming','his','name','is','xiao','li']for index,string in enumerate(strings): if 'name' in string: strings[index] = '$$$'print strings#翻转和排序print sorted([4,3,8,1,5,0])print sorted('hello , world !')print ''.join(sorted('hello,world!'))print reversed('hello,world!') #reversed 返回的不是列表,直接打印的话打印出来的是 一个对象 一个可迭代对象print type(reversed('hello,world!')) #<type 'reversed'>print list(reversed('hello,world!')) #类型转换转成 列表print ''.join(list(reversed('hello,world!'))) #链接列表元素,使形成一个字符串print type(''.join(list(reversed('hello,world!')))) #<type 'str'>#循环遍历字典元素,这里用到了序列解包的概念d = {'x':1,'y':2,'z':3}for key in d: #这里的这种循环就是获得的键值,和key这个变量的名字无关,这个key只是个普通的变量,本身毫无意义 print 'type(key):',type(key),"&&&&key=",key print key,"--->",d[key] for key,value in d.items(): #d.items()方法可以把一个键值对当做一个元组返回,在这个for循环中使用了序列解包 print key,'--->',value#并行迭代 内建的zip可以实现并行迭代 可以把两个序列压缩在一起返回一个元组names = ['xiaoming','xiaoli','xiaoxiao']ages = [10,20,50]for i in range(len(names)): print 'name:',names[i],'age:',ages[i] names_ages = zip(names,ages)print '压缩姓名和年龄后:',names_agesfor name,age in names_ages: #序列解压缩 print name,'is',age,'years old !'#如果两个序列的长度不相等 直到最短的序列迭代完后,就不再迭代 test = zip(range(5),xrange(1000000)) #有必要再说下range和xrange的区别 range会一次性计算完所有的数值,而xrange不会,xrange每次只计算一个数值 print test #[(0, 0), (1, 1), (2, 2), (3, 3), (4, 4)]