zoukankan      html  css  js  c++  java
  • 循环处理

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明。谢谢!(此处非原文,作为摘抄)

    range():

    在Python中,for循环后的in跟随一个序列的话,循环每次使用的序列元素,而不是序列的下标。

    S = 'abcdefghijk'
    for i in range(0,len(S),2):
        print(S[i])
    
    
    #执行结果:
    a
    c
    e
    g
    i
    k
    

    在该例子中,我们利用len()函数和range()函数,用i作为S序列的下标来控制循环。在range函数中,分别定义上限,下限和每次循环的步长。

    enumerate():

    利用enumerate()函数,可以在每次循环中同时得到下标和元素:

    S = 'abcdefghijk'
    for (index,char) in enumerate(S):
        print(index, char)
    
    #执行结果:
    0 a
    1 b
    2 c
    3 d
    4 e
    5 f
    6 g
    7 h
    8 i
    9 j
    10 k
    

    实际上,enumerate()在每次循环中,返回的是一个包含两个元素的定值表(tuple),两个元素分别赋予index和char

    zip():

    如果有多个等长序列,想每次取出一个元素,可以用zip():

    ta = [1,2,3]
    tb = [9,8,7]
    tc = ['a','b','c']
    for (a,b,c) in zip(ta,tb,tc):
        print(a,b,c)
    
    
    #执行结果:
    1 9 a
    2 8 b
    3 7 c
    

    每次循环时,从各个序列分别从左到右取出一个元素,合并成一个tuple。然后tuple的元素赋予给a,b,c。

    zip()函数的功能,就是从多给列表内,依次各取出一个元素,每次取出来的(来自不同列表)元素合并成一个元祖。合并成的元祖放在zip()返回的列表中。zip()起到了聚合列表的作用。

    可以分界聚合后的列表:

    ta = [1,2,3]
    tb = [9,8,7]
    
    # cluster
    zipped = zip(ta,tb)
    print(zipped)
    
    # decompose
    na, nb = zip(*zipped)
    print(na, nb)
    
    
    #执行结果:
    <zip object at 0x0000006C7FB35988>
    (1, 2, 3) (9, 8, 7)
    
  • 相关阅读:
    Java分享笔记:关于Java反射机制
    Java分享笔记:自定义枚举类 & 使用enum关键字定义枚举类
    Java分享笔记:RandomAccessFile流 & 在文件指定位置插入内容
    Spark-源码-SparkContext的初始化
    Spark-源码-Spark-StartAll Master Worler启动流程
    Spark-源码-Spark-Submit 任务提交
    Hadoop2学习路程-HDFS
    JavaSE 第二次学习随笔(五)
    JavaSE 第二次学习随笔(四)
    JavaSE 第二次学习随笔(三)
  • 原文地址:https://www.cnblogs.com/Guido-admirers/p/6163320.html
Copyright © 2011-2022 走看看