列表
序列是 Python 中最基本的数据结构。
序列中的每个值都有对应的位置值,称之为索引,第一个索引是 0,第二个索引是 1,依此类推。
Python 有 6 个序列的内置类型,但最常见的是列表和元组。
列表都可以进行的操作包括索引,切片,加,乘,检查成员。
此外,Python 已经内置确定序列的长度以及确定最大和最小的元素的方法。
列表是最常用的 Python 数据类型,它可以作为一个方括号内的逗号分隔值出现。
列表的数据项不需要具有相同的类型
一.访问列表中的值
与字符串的索引一样,列表索引从 0 开始,第二个索引是 1,依此类推。
通过索引列表可以进行截取、组合等操作。
实例
#!/usr/bin/python3
list = [‘red’, ‘green’, ‘blue’, ‘yellow’, ‘white’, ‘black’]
print( list[0] )
print( list[1] )
print( list[2] )
以上实例输出结果:
red
green
blue
索引也可以从尾部开始,最后一个元素的索引为 -1,往前一位为 -2,以此类推。
实例
#!/usr/bin/python3
list = [‘red’, ‘green’, ‘blue’, ‘yellow’, ‘white’, ‘black’]
print( list[-1] )
print( list[-2] )
print( list[-3] )
以上实例输出结果:
black
white
yellow
使用下标索引来访问列表中的值,同样你也可以使用方括号 [] 的形式截取字符,如下所示:
实例
#!/usr/bin/python3
nums = [10, 20, 30, 40, 50, 60, 70, 80, 90]
print(nums[0:4])
以上实例输出结果:
[10, 20, 30, 40]
使用负数索引值截取:
实例
#!/usr/bin/python3
list = [‘Google’, ‘Runoob’, “Zhihu”, “Taobao”, “Wiki”] # 读取第二位
print (“list[1]: “, list[1]) # 从第二位开始(包含)截取到倒数第二位(不包含)
print (“list[1:-2]:
“, list[1:-2])
以上实例输出结果:
list[1]: Runoob
list[1:-2]: [‘Runoob’, ‘Zhihu’]
二,修改列表
你可以对列表的数据项进行修改或更新,你也可以使用 append() 方法来添加列表项,如下所示:
实例(Python 3.0+)
#!/usr/bin/python3
list = [‘Google’, ‘Runoob’, 1997, 2000]
print (“第三个元素为 : “, list[2])
list[2] = 2001
print (“更新后的第三个元素为 : “, list[2])
list1 = [‘Google’, ‘Runoob’, ‘Taobao’]
list1.append(‘Baidu’) print (“更新后的列表 : “, list1)
注意:我们会在接下来的章节讨论 append() 方法的使用。
以上实例输出结果:
第三个元素为 : 1997
更新后的第三个元素为 : 2001
更新后的列表 : [‘Google’, ‘Runoob’, ‘Taobao’, ‘Baidu’]
三,删除列表元素
可以使用 del 语句来删除列表的的元素,如下实例:
实例(Python 3.0+)
#!/usr/bin/python3
list = [‘Google’, ‘Runoob’, 1997, 2000]
print (“原始列表 : “, list)
del list[2]
print (“删除第三个元素 : “, list)
以上实例输出结果:
原始列表 : [‘Google’, ‘Runoob’, 1997, 2000]
删除第三个元素 : [‘Google’, ‘Runoob’, 2000]
注意:我们会在接下来的章节讨论 remove() 方法的使用
四,Python列表脚本操作符
列表对 + 和 * 的操作符与字符串相似。+ 号用于组合列表,* 号用于重复列表。
如下所示:
Python 表达式 |
结果 |
描述 |
len([1, 2, 3]) |
3 |
长度 |
[1, 2, 3] + [4, 5, 6] |
[1, 2, 3, 4, 5, 6] |
组合 |
[‘Hi!’] * 4 |
[‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’] |
重复 |
3 in [1, 2, 3] |
True |
元素是否存在于列表中 |
for x in [1, 2, 3]: print(x, end=” “) |
1 2 3 |
迭代 |
Python列表截取与拼接
Python的列表截取与字符串操作类型,如下所示:
L=[‘Google’, ‘Runoob’, ‘Taobao’]
操作:
Python 表达式 |
结果 |
描述 |
L[2] |
‘Taobao’ |
读取第三个元素 |
L[-2] |
‘Runoob’ |
从右侧开始读取倒数第二个元素: count from |
L[1:] |
[‘Runoob’, ‘Taobao’] |
输出从第二个元素开始后的所有元素 |
>>>L=[‘Google’, ‘Runoob’, ‘Taobao’]
>>>
L[2] ‘Taobao’
>>> L[-2] ‘Runoob’
>>>
L[1:] [‘Runoob’, ‘Taobao’]
>>>
列表还支持拼接操作:
>>>squares = [1, 4, 9, 16, 25]
>>>
squares += [36, 49, 64, 81, 100]
>>>
squares [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
>>>
嵌套列表
使用嵌套列表即在列表里创建其它列表,例如:
>>>a = [‘a’, ‘b’, ‘c’]
>>>
n = [1, 2, 3]
>>>
x = [a, n]
>>>
x [[‘a’, ‘b’, ‘c’], [1, 2, 3]]
>>>
x[0] [‘a’, ‘b’, ‘c’]
>>>
x[0][1] ‘b’
Python列表函数&方法
Python包含以下函数:
序号 |
函数 |
1 |
len(list) |
2 |
max(list) |
3 |
min(list) |
4 |
list(seq) |
Python包含以下方法:
序号 |
方法 |
1 |
list.append(obj) |
2 |
list.count(obj) |
3 |
list.extend(seq) |
4 |
list.index(obj) |
5 |
list.insert(index, obj) |
6 |
list.pop([index=-1]) |
7 |
list.remove(obj) |
8 |
list.reverse() |
9 |
list.sort( key=None, reverse=False) |
10 |
list.clear() |
11 |
list.copy() |
本节例子
#list[] (列表)
#列表索引
#x=[‘hello’,1,2,3.0,4.0,True,False]
#x[1] ==> 1
#x[] 表示索引
#x[-1]
==> False
#x[len(x)-1] ==> False
#列表切片
#x[1:3] ==> [1,2]
#切片范围为左闭右开
#x[:4]
x[4:] ==> #0可以省略
#列表判断某个元素是否在列表
#’This’
in ‘This is a boy’
#’to’ in
‘This is a boy’
#print([1]
in [1,2,3,4,5]) #[1] 和 1 不同
#print(1
in [1,2,3,4,5])
#列表和字符串的可变性
#x=’hello’
#print(x[1])
#
#list=[1,2,3,4,5]
#list[1]
#
#list[0]=5 ==> [5,2,3,4,5] #列表可以该内容,但字符串不能改
#ry=’roy’
#ry[1]=’w’
#这样子是不行的
#应该是ry=’rwy’
#实用列表函数
#x=[1,2,3,4,5,6,7,8]
#len(x) ==> 8
#max(x) ==> 最大值
#min(x) ==> 最小值
#sorted(x) ==> 从小到大排序
#sorted(x,reverse=True) ==>从大到小排序
#x可以是数
也可以是字符串 字符串要定义 不能就[a,a,b,c,d] 要[‘a’,’a’,’b’,’c’,’d’]
#l列表方法join
#a=[‘A’,’B’,’C’,’D’]
#b=’/n’.join(a) # 表示竖列表示 # /n 表示换行
#print(b)
# join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串。
#列表方法append
#name=[‘x’,’y’,’z’,’q’]
#name.append(‘w’) #只能一个一个加不能。append(‘w’,’e’)
在列表最后一个后面加
#集合和列表去重
#x=[‘1′,’2′,’3′,’3′,’4′,’3’]
#x=[1,2,3,4,5]
#y=set(x)
#print(y)
不免有遗漏地点和自身不足的地方,还需努力
原创文章,作者:254126420,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/244393.html