>>> squares =[]
>>> for x in range(10):
... squares.append(x**2)
>>> squares
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
=>
squares = list(map(lambda x: x**2, range(10)))
=>
squares = [x**2for x in range(10)]
>>> [(x,y) for x in [1,2,3] for y in [3,1,4] if x != y]
[(1,3), (1,4), (2,3), (2,1), (2,4), (3,1), (3,4)]
>>> # equivalent to:>>> combs = []
>>> for x in [1, 2, 3]:
... for y in [3, 1, 4]:
... if x != y:
... combs.append((x, y))
>>> combs
>>> vec = [-4, -2, 0, 2, 4]
>>> # create a new list with the values doubled>>> [x*2for x in vec]
[-8, -4, 0, 4, 8]
>>> # filter the list to exclude negative numbers>>> [x for x in vec if x >= 0]
[0, 2, 4]
>>> # apply a function to all the elements>>> [abs(x) for x in vec]
[4, 2, 0, 2, 4]
>>> # call a method on each element>>> freshfruit = [' banana', ' loganberry ', 'passion fruit ']
>>> [weapon.strip() for weapon in freshfruit]
['banana', 'loganberry', 'passion fruit']
>>> # create a list of 2-tuples like (number, square)>>> [(x, x**2) for x in range(6)]
[(0, 0), (1, 1), (2, 4), (3, 9), (4, 16), (5, 25)]
>>> # the tuple must be parenthesized, otherwise an error is raised>>> [x, x**2for x in range(6)]
File "<stdin>", line 1, in ?
[x, x**2for x in range(6)]
^
SyntaxError: invalid syntax
>>> # flatten a list using a listcomp with two 'for'>>> vec = [[1,2,3], [4,5,6], [7,8,9]]
>>> [num for elem in vec for num in elem]
[1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> # 列表推导式可使用复杂的表达式和嵌套函数:>>> from math import pi
>>> [str(round(pi, i)) for i in range(1, 6)]
['3.1', '3.14', '3.142', '3.1416', '3.14159']
>>> a = [-1, 1, 66.25, 333, 333, 1234.5]
>>> del a[0]
>>> a
[1, 66.25, 333, 333, 1234.5]
>>> del a[2:4]
>>> a
[1, 66.25, 1234.5]
>>> del a[:]
>>> a
[]
>>> # del 也可以删除整个变量>>> del a
Set 集合
>>> basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
>>> print(basket) # show that duplicates have been removed
{'orange', 'banana', 'pear', 'apple'}
>>> 'orange'in basket # fast membership testingTrue>>> 'crabgrass'in basket
False>>> # Demonstrate set operations on unique letters from two words
...
>>> a = set('abracadabra')
>>> b = set('alacazam')
>>> a # unique letters in a
{'a', 'r', 'b', 'c', 'd'}
>>> a - b # letters in a but not in b
{'r', 'd', 'b'}
>>> a | b # letters in either a or b
{'a', 'c', 'r', 'd', 'b', 'm', 'z', 'l'}
>>> a & b # letters in both a and b
{'a', 'c'}
>>> a ^ b # letters in a or b but not both
{'r', 'd', 'b', 'm', 'z', 'l'}
>>> #类似 for lists ,这里有一种集合推导式语法>>> a = {x for x in'abracadabra'if x notin'abc'}
>>> a
{'r', 'd'}
Dictionaries 字典
>>> tel = {'jack': 4098, 'sape': 4139}
>>> tel['guido'] = 4127>>> tel
{'sape': 4139, 'guido': 4127, 'jack': 4098}
>>> tel['jack']
4098>>> del tel['sape']
>>> tel['irv'] = 4127>>> tel
{'guido': 4127, 'irv': 4127, 'jack': 4098}
>>> list(tel.keys())
['irv', 'guido', 'jack']
>>> sorted(tel.keys())
['guido', 'irv', 'jack']
>>> 'guido'in tel
True>>> 'jack'notin tel
False
>>> # 在字典中循环时,关键字和对应的值可以使用 iteritems() 方法同时解读出来>>> knights = {'gallahad': 'the pure', 'robin': 'the brave'}
>>> for k, v in knights.items():
... print(k, v)
...
gallahad the pure
robin the brave
>>> # 在序列中循环时,索引位置和对应值可以使用 enumerate() 函数同时得到>>> for i, v in enumerate(['tic', 'tac', 'toe']):
... print(i, v)
...
0 tic
1 tac
2 toe
>>> # 同时循环两个或更多的序列,可以使用 zip() 整体打包>>> questions = ['name', 'quest', 'favorite color']
>>> answers = ['lancelot', 'the holy grail', 'blue']
>>> for q, a in zip(questions, answers):
... print('What is your {0}? It is {1}.'.format(q, a))
...
What is your name? It is lancelot.
What is your quest? It is the holy grail.
What is your favorite color? It is blue.
>>> # 需要逆向循环序列的话,先正向定位序列,然后调用 reversed() 函数>>> for i in reversed(range(1, 10, 2)):
... print(i)
...
97531>>> # 要按排序后的顺序循环序列的话,使用 sorted() 函数,它不改动原序列,而是生成一个新的已排序的序列>>> basket = ['apple', 'orange', 'apple', 'pear', 'orange', 'banana']
>>> for f in sorted(set(basket)):
... print(f)
...
apple
banana
orange
pear
More on Conditions 深入条件控制
>>> string1, string2, string3 = '', 'Trondheim', 'Hammer Dance'>>> non_null = string1 or string2 or string3
>>> non_null
'Trondheim'