列表(list)是Python中一个非常重要的类型,用于管理一组数据,列表的形式如下所示
country = [‘China‘, ‘Germany‘, ‘Russia‘, ‘America‘]
1)数据包含在引号中,Python中单引号和双引号具有相同的作用
2)使用逗号分隔数据,整个列表包含在一个中括号中
3)适用赋值操作符将一个列表赋值给一个变量名如上述例子中的“country”, Python的变量名不需要声明类型
country = []
列表不仅可以存放字符串这样的数据,还可以存放混合类型的数据,例如在列表中存储列表
country = [‘China‘,
[‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘],
‘Germany‘, ‘Russia‘, ‘America‘
]
print(country)
print(country[1][2])
print(country[0:2])
>>[‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘]
>>Shenzhen
>>[‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘]]
除了列表外还可以存储字典和元组,字典和元组另作介绍
列表可以像数组那样通过下标获取列表中的数据,数据类型---字符串
print(country[0]) >>>China
列表可以适用冒号“:”操作符选取列表中的一部分数据,选取出的数据成为切片,实际上是字列表,但这些数据需要是连续的。
此外数据可以正向取如示例中的“0 : 2”得到列表[‘China‘, ‘Germany‘], 也可以反向取如“-2:-1”
需要注意的是即使切片只取一个数据得到的也是一个列表,而不是一个字符串,与使用索引得到的数据是不同的
country = [‘China‘, ‘Germany‘, ‘Russia‘, ‘America‘] print(country) print(country[0:1]) print(country[0:2]) print(country[-2: -1]) >>[‘China‘, ‘Germany‘, ‘Russia‘, ‘America‘] >>[‘China‘] >>[‘China‘, ‘Germany‘] >>[‘Russia‘]
添加数据可以使用insert()和append()两种方法,如下所示:
country = [‘China‘, ‘Germany‘, ‘Russia‘, ‘America‘] country.insert(1, ‘Grace‘) print(country) country.append(‘Mexico‘) print(country) >>[‘China‘, ‘Grace‘, ‘Germany‘, ‘Russia‘, ‘America‘] >>[‘China‘, ‘Grace‘, ‘Germany‘, ‘Russia‘, ‘America‘, ‘Mexico‘]
insert()第一个参数确定插入的位置,在这个位置之后插入需要插入的数据, append()将数据添加到列表的尾部
country = [‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘ ] Eur = [‘England‘, ‘France‘] country.extend(Eur) print(country) >>[‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘, ‘England‘, ‘France‘]
从列表中找出某个值第一个匹配项的索引位置
country = [‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘ ] print(country.index(‘Germany‘)) print(country.index([‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘])) >>2 >>1
只能查找第一层数据,如果差列表中的列表,需要将列表全部输入。函数中的start和stop用于确定搜索范围
移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
country = [‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘ ] print(country) print(country.pop(-2)) print(country) >>[‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘] >>Russia >>[‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘America‘]
移除列表中某个值的第一个匹配项
country = [‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘, ‘Russia‘ ] print(country) country.remove(‘Russia‘) print(country) >>[‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘, ‘Russia‘] >>[‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘America‘, ‘Russia‘]
反向列表中元素
country = [‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘, ‘Russia‘ ] print(country) country.reverse() print(country) >> [‘China‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘Germany‘, ‘Russia‘, ‘America‘, ‘Russia‘] >>[‘Russia‘, ‘America‘, ‘Russia‘, ‘Germany‘, [‘Beijing‘, ‘Shanghai‘, ‘Shenzhen‘], ‘China‘]
对原列表进行排序
country = [‘China‘, ‘Germany‘, ‘Russia‘, ‘America‘] print(country) country.sort() print(country) >>[‘China‘, ‘Germany‘, ‘Russia‘, ‘America‘] >>[‘America‘, ‘China‘, ‘Germany‘, ‘Russia‘]
原文:http://www.cnblogs.com/Techml/p/6490818.html