python 中的迭代 for zip 字典

来源:互联网 发布:网络监控的组成 编辑:程序博客网 时间:2024/05/22 14:46
#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)]

原创粉丝点击