增:
L = ['Adam', 'Lisa', 'Bart']
L.append('Paul')
print L # ['Adam', 'Lisa', 'Bart', 'Paul']
L = ['Adam', 'Lisa', 'Bart']
L.insert(0, 'Paul')
print L # ['Paul', 'Adam', 'Lisa', 'Bart']
L = ['Adam', 'Lisa', 'Bart']
L.insert(-1, 'Paul')
print L # ['Adam', 'Lisa','Paul', 'Bart']
因为insert是前插,而不是append的后插,链表,也有前插和后插,道理一样的,insert定义的时候就是插在原来那个位置的元素的前边。
删:
L = ['Adam', 'Lisa', 'Bart']
L.pop(1) # ['Adam', 'Bart']
改:
L = ['Adam', 'Lisa', 'Bart']
L[0] = 'Bdam' # ['Bdam', 'Lisa', 'Bart']
tuple没有append() insert() pop() 不能增删改
tuple中只有一个元素时:
t = (1)
print t # 1 ,输出的是一个整数1 而不是元组,因为()既可以表示tuple,又可以作为括号表示运算时的优先级,结果 (1) 被Python解释器计算出结果 1,导致我们得到的不是tuple,而是整数 1
t=(1,)
print t #(1,) 正是因为用()定义单元素的tuple有歧义,所以 Python 规定,单元素 tuple 要多加一个逗号“,”,这样就避免了歧义.
tuple是不可改变,但tuple里面的list是可改变的
list通过索引返回对应元素;dict使用key返回对应的value
避免出现keyerror:2种方法:
1.判断key是否存在
if 'Paul' in d:
print d['Paul']
2.使用dict本身的一个get方法
print d.get('Paul') # 不存在会返回None
dict以key:value的形式输出
for key in d:
print("%s:%s" %(key,d[key])) #通过key查value: d[key]
使用set set元素没有重复,而且无序,与dict的key很像
s = set(['Adam','Lisa','Bart'])
for name in s:
print name
t = set([('Adam',98),('Lisa',87),('Bart',99)])
for n in t:
print("%s:%s" %(t[0],t[1]))
#
Adam:98
Lisa:87
Basrt:99