list(列表)、tuple(元组)、dict(字典) 、 set(集合)
一、list(列表)
定义list,用中括号。例如:
classmates = ['Michael', 'Bob', 'Tracy']
访问元素,用索引。例如:
#以下引用'Michael'
classmates[0] #以下引用倒数第一个,即'Tracy'
classmates[-1]
追加元素到末尾。例如:
classmates.append('Adam')
删除list末尾的元素。例如:
classmates.pop()
删除指定位置的元素:
classmates.pop(1)
替换成别的元素,可以直接赋值给对应的索引位置:
classmates[1] = 'Sarah'
list元素也可以是另一个list,比如:
s = ['python', 'java', ['asp', 'php'], 'scheme'] 或 p = ['asp', 'php'] s = ['python', 'java', p, 'scheme']
二、tuple(元组)
tuple使用小括号定义,且一旦初始化就不能修改。例如:
t = (1, 2)
要定义一个空的tuple,可以写成:
t = ()
要定义一个只有1个元素的tuple,必须添加一个逗号:
t = (1,)
因为写成:t = (1) 时,电脑会把()看作是数据运算符号,其效果和 t = 1 是一样的。
最后来看一个“可变的”tuple:
>>> t = ('a', 'b', ['A', 'B']) >>> t[2][0] = 'X' >>> t[2][1] = 'Y' >>> t ('a', 'b', ['X', 'Y'])
表面上看,tuple的元素确实变了,但其实变的不是tuple的元素,而是list的元素。
三、dict(字典)
字典的定义,用大括号。例如:
>>> d = {'Michael': 95, 'Bob': 75, 'Tracy': 85} >>> d['Michael'] 95
把数据放入dict的方法
>>> d['Adam'] = 67 >>> d['Adam'] 67
要避免key不存在的错误,有两种办法,一是通过 in 判断key是否存在:
>>> 'Thomas' in d False
二是通过dict提供的 get() 方法,如果key不存在,可以返回 None ,或者自己指定的value:
>>> d.get('Thomas') >>> d.get('Thomas', -1) -1
要删除一个key,用 pop(key) 方法,对应的value也会从dict中删除:
>>> d.pop('Bob') 75 >>> d {'Michael': 95, 'Tracy': 85}
四、set(集合)
set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
要创建一个set,用大括号。例如:
>>> s = {1, 2, 3} >>> s {1, 2, 3}
或者提供一个list作为输入集合:
>>> s = set([1, 2, 3]) >>> s {1, 2, 3}
重复元素在set中自动被过滤:
>>> s = {1, 1, 2, 2, 3, 3} >>> s {1, 2, 3}
通过 add(key) 方法可以添加元素到set中,可以重复添加,但不会有效果:
>>> s.add(4) >>> s {1, 2, 3, 4} >>> s.add(4) >>> s {1, 2, 3, 4}
通过 remove(key) 方法可以删除元素:
>>> s.remove(4) >>> s {1, 2, 3}
set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、
并集等操作:
>>> s1 = {1, 2, 3} >>> s2 = {2, 3, 4} >>> s1 & s2 {2, 3} >>> s1 | s2 {1, 2, 3, 4}