现在的位置: 首页 > 综合 > 正文

python 中的迭代 for zip 字典

2014年03月08日 ⁄ 综合 ⁄ 共 1617字 ⁄ 字号 评论关闭
#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 += 1
print 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_ages
for 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)]

抱歉!评论已关闭.