一 列表:list
1.定义
Python内置的一种数据类型。是一种有序的集合,可以随时添加和删除其中的元素。
>>> classmates=['Michael','Bob','Tracy']>>> classmates['Michael', 'Bob', 'Tracy']变量 classmates
就是一个list,list里面的元素的数据类型也可以不同。
2.基本操作
1)len()
:获得list元素的个数。
2)classmates[0]
:通过索引访问list中的元素。要取最后一个元素,除了计算索引位置外,还可以用-1做索引,直接获取最后一个元素。以此类推,可以获取倒数第2个、倒数第3个。
3)classmates.append('Adam')
:往list中追加元素到末尾。
4)classmates.insert(1, 'Jack')
:把元素插入到指定的位置。
5)pop()
:删除list末尾的元素。
6)pop(i)
: 删除list中指定位置的元素。
7)classmates[1] = 'Sarah'
:某个元素替换成别的元素,直接赋值给对应的索引位置。
3.二维列表
list元素可以是另一个list:
>>> s = ['python', 'java', ['asp', 'php'], 'scheme']>>> len(s)4或者
>>> p = ['asp', 'php']>>> s = ['python', 'java', p, 'scheme']要拿到'php'
可以写p[1]
或者s[2][1]
。
二 元祖:tuple
1.定义
Python中另一种有序列表。tuple和list非常类似,但是tuple一旦初始化就不能修改。
因为tuple不可变,所以代码更安全。如果可能,能用tuple代替list就尽量用tuple。
>>> classmates = ('Michael', 'Bob', 'Tracy')2.基本操作
没有append(),insert()这样的方法,其他获取元素的方法和list是一样的。
你可以正常地使用classmates[0]
,classmates[-1]
,但不能赋值成另外的元素。
3.tuple的陷阱
当你定义一个tuple时,在定义的时候,tuple的元素就必须被确定下来。例如:
>>> t = (1, 2)>>> t(1, 2)如果要定义一个空的tuple,可以写成()
:
但是,要定义一个只有1个元素的tuple,如果你这么定义:
>>> t = (1)>>> t1定义的不是tuple,是1这个数!这是因为括号()既可以表示tuple,又可以表示数学公式中的小括号,这就产生了歧义。
因此,Python规定,这种情况下,按小括号进行计算,计算结果自然是1。
所以,只有1个元素的tuple定义时必须加一个逗号,,来消除歧义:
>>> t = (1,)>>> t(1,)Python在显示只有1个元素的tuple时,也会加一个逗号,,以免误解成数学计算意义上的括号。
4.“可变的”tuple
>>> t = ('a', 'b', ['A', 'B'])>>> t[2][0] = 'X'>>> t[2][1] = 'Y'>>> t('a', 'b', ['X', 'Y'])定义的时候tuple包含的3个元素:
当把list的元素'A'
和'B'
修改为'X'
和'Y'
后,tuple变为:
表面上看,tuple的元素确实变了。但其实变的不是tuple的元素,而是list的元素,tuple一开始指向的list并没有改成别的list。
所以,tuple所谓的“不变”是说:tuple的每个元素,指向永远不变。即指向’a’,就不能改成指向’b’,指向一个list,就不能改成指向其他对象,但指向的这个list本身是可变的。
要创建一个内容也不变的tuple怎么做?那就必须保证tuple的每一个元素本身也不能变。
转自http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/001386819318453af120e8751ea4d2696d8a1ffa5ffdfd7000
新闻热点
疑难解答