• Python编程核心内容之二——切片、迭代和列表生成式


      Python版本:3.6.2  操作系统:Windows  作者:SmallWZQ

      最近太忙啦。很多事情需要自己处理,感觉时间不够用啊~~~~今后,博客更新时间可能会慢下来(但不能荒废了学习,要学习就得进行总结,哪怕借鉴前辈的学习资料),因此,无论闲忙,总是要学会总结。哈哈,正所谓“人不为己,天诛地灭”嘛。嘿嘿,没这么回事,说笑的……好像又扯远了。OK,回归正题,下面将回到Python先~~~

      Python编程中,你如果要编写出很多有用的程序,必须掌握数据类型、语句和函数。对于Python编程,原则有二:一是代码不是越多越好,而是越少越好;二是代码不是越复杂越好,而是越简单越好。你还想“一行代码两块钱”。效率决定一切。

      下面来个例子(不然,全是文字,会晕~~~)【实现1,3,5,7,9,……99的列表】:

     1 #赚钱版代码
     2 >>>n = 1
     3 >>>L = []
     4 >>>while n <= 99:
     5 ...    L.append(n)
     6 ...    n = n + 2
     7 ...
     8 >>>print(L)        #好多money,但老板不一定会给噢
     9 #略缩版代码
    10 >>>L= list(range(1,100,2))
    11 >>>print(L)
    12 #终极版代码
    13 >>>[x for x in range(1,100,2)]

      其实,上述代码涉及到的代码主要包括循环、range()、分片、列表生成式。通过例子,我们知道:Python提供了很多有用的高级特性,灵活运用这些特性,可以减少我们很多代码量,提高效率。

    切片

      切片是Python编程的高级特性之一。切片可以访问一定范围内的元素,通过冒号(:)【该冒号是英文版的】隔开两个索引实现。

      关于Python编程中的符号(比如冒号,逗号,括号……)都是英文版的【重要的事情说好多遍,因为自己平时编程也会时常出现这类错误】,否则程序编译会有Error,而且这种类型的错误还不好发现。因此,细节决定高度~~~

    1 #切片的魔力
    2 >>>L = [1,2,3,4,5,6,7,8,9,10]
    3 >>>L[2:5]
    4 3,4,5
    5 >>>L[0:1]
    6 1

      切片操作的实现需要提供两个索引作为边界,第一个索引的元素是包含在切片内的,而第二个则不包含在切片内。

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

    1 >>>L = [1,2,3,4,5,6,7,8,9,10]
    2 >>>L[0:3]
    3 1,2,3
    4 >>>L[:3]
    5 1,2,3

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

    1 >>>L = [1,2,3,4,5,6,7,8,9,10]
    2 >>>L[-2:]
    3 9,10
    4 >>>L[-2,-1]
    5 9

      Python 3.x版本中,切片操作还支持步长

    1 >>>L = [1,2,3,4,5,6,7,8,9,10]
    2 >>>L[::1]
    3 [1,2,3,4,5,6,7,8,9,10]
    4 >>>L[0:10:2]
    5 [1,3,5,7,9]
    6 >>>L[1:10:5]
    7 [2,7]

      tuple也是一种list,唯一区别是tuple不可变。因此,tuple也可以用切片操作,只是操作的结果仍是tuple:

    1 >>> (0, 1, 2, 3, 4, 5)[:3]
    2 (0, 1, 2)

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

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

      Python没有针对字符串的截取函数,只需要切片一个操作就可以完成,非常简单。

      Python的切片非常灵活,一行代码就可以实现很多行循环才能完成的操作。

    迭代

      Iteration是Python编程中最重要的高级特性。迭代(Iteration):给定一个list或tuple,通过for循环来遍历这个list或tuple。故而,Python是通过for...in循环实现迭代的。

      list这种数据类型虽然有下标,但很多其他数据类型是没有下标的,但是,只要是可迭代对象,无论有无下标,都可以迭代,比如dict就可以迭代:

    1 >>> d = {'A': 1, 'B': 2, 'C': 3}
    2 >>> for key in d:
    3 ...    print(key)
    4 ...
    5 A
    6 B
    7 C
    8 >>> 

      因为dict的存储不是按照list的方式顺序排列,所以,迭代出的结果顺序很可能不一样。

      默认情况下,dict迭代的是key。如果要迭代value,可以用for value in d.values(),如果要同时迭代key和value,可以用for k, v in d.items()

      由于字符串也是可迭代对象,因此,也可以作用于for循环:

    1 >>> for ch in 'ABC':
    2 ...     print(ch)
    3 ...
    4 A
    5 B
    6 C

      因此,当我们使用for循环时,只要作用于一个可迭代对象,for循环就可以正常运行,而我们不太关心该对象究竟是list还是其他数据类型。

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

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

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

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

      任何可迭代对象都可以作用于for循环,包括我们自定义的数据类型,只要符合迭代条件,就可以使用for循环。

    列表生成式

      列表生成式作为Python编程的高级特性,可以简化不少代码量。列表生成式(List Comprehensions)是Python内置的非常简单却强大的可以用来创建list的生成式。

       举个例子,要生成list [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]可以用list(range(1, 11)):

    1 >>> list(range(1, 11))
    2 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

      但如果要生成[1x1, 2x2, 3x3, …, 10x10]怎么做?方法一是循环:

    1 >>> L = []
    2 >>> for x in range(1, 11):
    3 ...    L.append(x * x)
    4 ...
    5 >>> L
    6 [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

      但是循环太繁琐,而列表生成式则可以用一行语句代替循环生成上面的list:

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

      写列表生成式时,把要生成的元素x * x放到前面,后面跟for循环,就可以把list创建出来,for循环后面还可以加上if判断,这样我们就可以筛选出仅偶数的平方:

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

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

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

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

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

      列表生成式不是真正的语句,而是看起来像循环的表达式,这是将它归为循环语句的原因。该功能很强大,但大多数情况下,直接使用循环和条件语句也能完成。然而,列表生成式的程序十分简洁,更加易读。

      下面来个例子:

    1 L1 = ['Hello', 'World', 18, 'Apple', None]
    2 L2= [s.lower() for s in L1 if isinstance(s,str)]
  • 相关阅读:
    bzoj2957 -- 线段树
    bzoj2209 [ JSOI2011 ] -- splay
    bzoj3874 [ AHOI2014 ] -- 爬山算法
    bzoj1038 [ ZJOI2008 ] -- 模拟退火+二分
    bzoj2428 [ HAOI2006 ] -- 模拟退火
    bzoj3680 -- 模拟退火
    bzoj4500 -- 差分约束
    bzoj3527 -- FFT
    bzoj1013 [ JSOI2008 ] -- 高斯消元
    使用nginx try_files 指令 管理静态资源
  • 原文地址:https://www.cnblogs.com/SmallWZQ/p/8544521.html
Copyright © 2020-2023  润新知