美文网首页Python
2019-05-15 切片与迭代

2019-05-15 切片与迭代

作者: 沙滩印 | 来源:发表于2019-05-15 14:28 被阅读0次

    取一个list或tuple的部分元素是非常常见的操作。比如,一个list如下:

    >>> L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack']
    

    取前3个元素,用一行代码就可以完成切片:

    >>> L[0:3]
    ['Michael', 'Sarah', 'Tracy']
    

    L[0:3]表示,从索引0开始取,直到索引3为止,但不包括索引3。即索引0,1,2,正好是3个元素。

    如果第一个索引是0,还可以省略:

    >>> L[:3]
    ['Michael', 'Sarah', 'Tracy']
    

    也可以从索引1开始,取出2个元素出来:

    >>> L[1:3]
    ['Sarah', 'Tracy']
    

    类似的,既然Python支持L[-1]取倒数第一个元素,那么它同样支持倒数切片,试试:

    >>> L[-2:]
    ['Bob', 'Jack']
    >>> L[-2:-1]
    ['Bob']
    

    记住倒数第一个元素的索引是-1。

    字符串'xxx'也可以看成是一种list,每个元素就是一个字符。因此,字符串也可以用切片操作,只是操作结果仍是字符串:

    >>> 'ABCDEFG'[:3]
    'ABC'
    >>> 'ABCDEFG'[::2]
    'ACEG'
    

    在很多编程语言中,针对字符串提供了很多各种截取函数(例如,substring),其实目的就是对字符串切片。Python没有针对字符串的截取函数,只需要切片一个操作就可以完成,非常简单。

    练习:

    利用切片操作,实现一个trim()函数,去除字符串首尾的空格,注意不要调用str的strip()方法:

    # -*- coding: utf-8 -*-
    def trim(s):
    
        while s[0:1]==' ':    
          s = s[1:]
        while s[-1:]==' ':    
          s = s[:-1]
        return s
    

    测试:

    if trim('hello ') != 'hello':
    print('测试失败!')
    elif trim(' hello') != 'hello':
    print('测试失败!')
    elif trim(' hello ') != 'hello':
    print('测试失败!')
    elif trim(' hello world ') != 'hello world':
    print('测试失败!')
    elif trim('') != '':
    print('测试失败!')
    elif trim(' ') != '':
    print('测试失败!')
    else:
    print('测试成功!')
    Run

    测试成功!

    如何判断一个对象是可迭代对象呢?方法是通过collections模块的Iterable类型判断:

    >>> from collections import Iterable
    >>> isinstance('abc', Iterable) # str是否可迭代
    True
    >>> isinstance([1,2,3], Iterable) # list是否可迭代
    True
    >>> isinstance(123, Iterable) # 整数是否可迭代
    False
    

    如果要对list实现类似Java那样的下标循环怎么办?
    Python内置的enumerate函数可以把一个list变成索引-元素对,这样就可以在for循环中同时迭代索引和元素本身:

    >>> for i, value in enumerate(['A', 'B', 'C']):
    ...     print(i, value)
    ...
    0 A
    1 B
    2 C
    

    上面的for循环里,同时引用了两个变量,在Python里是很常见的,比如下面的代码:

    >>> for x, y in [(1, 1), (2, 4), (3, 9)]:
    ...     print(x, y)
    ...
    1 1
    2 4
    3 9
    

    列表生成式

    >>> [x * x for x in range(1, 11)]
    [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
    

    列表生成式时,把要生成的元素x * x放到前面,后面跟for循环,就可以把list创建出来。

    for循环后面还可以加上if判断,这样我们就可以筛选出仅偶数的平方:

    >>> [x * x for x in range(1, 11) if x % 2 == 0]
    [4, 16, 36, 64, 100]
    

    还可以使用两层循环,可以生成全排列:

    >>> [m + n for m in 'ABC' for n in 'XYZ']
    ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
    

    运用列表生成式,可以写出非常简洁的代码。例如,列出当前目录下的所有文件和目录名,可以通过一行代码实现:

    >>> import os # 导入os模块,模块的概念后面讲到
    >>> [d for d in os.listdir('.')] # os.listdir可以列出文件和目录
    ['.emacs.d', '.ssh', '.Trash', 'Adlm', 'Applications', 'Desktop', 'Documents', 'Downloads', 'Library', 'Pictures', 'Public']
    

    for循环其实可以同时使用两个甚至多个变量,比如dict的items()可以同时迭代key和value:

    >>> d = {'x': 'A', 'y': 'B', 'z': 'C' }
    >>> for k, v in d.items():
    ...     print(k, '=', v)
    ...
    y = B
    x = A
    z = C
    

    因此,列表生成式也可以使用两个变量来生成list:

    >>> d = {'x': 'A', 'y': 'B', 'z': 'C' }
    >>> [k + '=' + v for k, v in d.items()]
    ['y=B', 'x=A', 'z=C']
    

    最后把一个list中所有的字符串变成小写:

    >>> L = ['Hello', 'World', 'IBM', 'Apple']
    >>> [s.lower() for s in L]
    ['hello', 'world', 'ibm', 'apple']
    

    相关文章

      网友评论

        本文标题:2019-05-15 切片与迭代

        本文链接:https://www.haomeiwen.com/subject/mcupaqtx.html