使用list和tuple


list

  1、基本概念: python内置的一种数据类型是列表:list,list是一种有序的集合,可以随时添加和删除其中的元素:

>>>classmates = ['Michael','Bob','Tracy']
>>>classmates
['Michael','Bob','Tracy']

  2、列表list索引: 可以使用索引来访问list中的每一个位置的元素,并且和c++一样也是从0 开始的,不过有意思的是,如果我们要取最后一个元素,除了计算索引位置外,还可以用-1做索引,直接获取最后一个元素:

>>>classmates[-1]
'Tracy'

以此类推,可以获取倒数第2个、倒数第3个:

>>>classmates[-2]
'Bob'
>>>classmates[-3]
'Michael'

  3、方法:

  • len(): 用len()函数可以获得list元素的个数

    >>>len(classmates)
    3
    
  • append(): 可以往list中追加元素到末尾

    >>>classmates.append('Adam')
    >>>classmates
    ['Michael','Bob','Tracy','Adam']
    
  • insert(): 把元素插入到指定的位置

    >>>classmates.insert(1,'Jack')
    >>>classmates
    ['Michael','Jack','Bob','Tracy','Adam']
    
  • pop(): 可以删除list末尾的元素,也可以删除指定位置的元素

    >>>classmates.pop()
    >>>classmates.pop(2)    # 删除位置为2的元素
    

    4、元素的数据类型: list里面的元素的数据类型是可以不同的,比如

    >>>L = ['Apple', 123, True]
    

    list元素也可以是另一个list,比如:

    >>>s = ['python', 'java', ['asp', 'php'], 'scheme']
    >>> len(s)
    4
    

      假如我们要取‘php’可以写成s_[2]_[1],因此s可以看成是一个二维数组

tuple

  1、另一种有序列表叫元组 :tuple。tuple和list非常类似,但是tuple一旦初始化就不能修改 。因为tuple不可变,所以代码更安全。如果可能,能用tuple代替list就尽量用tuple。

  2、tuple的陷阱: 当定义一个tuple时,在定义的时候,tuple的元素就必须被确定下来,比如:

>>>t = (1, 2)
>>>t
(1, 2)

  如果要定义一个空的tuple,可以写成()。但是,要定义一个只有一个元素的tuple,如果这么定义:

>>>t = (1)
>>>t
1

  定义的不是tuple,是1这个数!这是因为括号()既可以表示tuple,又可以表示数学公式中的小括号,这就产生了歧义,因此,python规定,这种情况下,按小括号计算,计算结果自然是1。
  所以,只有1个元素的tuple定义时必须加一个逗号,来消除歧义:

>>>t = (1,)
>>>t
(1,)

  3、“可变的”tuple:

>>>t = ('a', 'b', ['A', 'B'])
>>>t[2][0]='X'
>>>t[2][1]='Y'
>>>t
('a', 'b', ['X', 'Y'])

  这个tuple定义的时候有3个元素,分别是'a'、'b'、和一个list。不是说tuple一旦定义下来就不可变了吗?,其实tuple所谓的“不变”是说,tuple每个元素,指向永远不变,即指向'a',就不能改成指向'b',指向一个list,就不能改成指向其他对象,但指向的这个list本身是可变的!

  注意: 定义list使用[ ......],而tuple使用(.........),dict和set使用{........}。

原文地址:https://www.cnblogs.com/xipuhu/p/7456605.html