zl程序教程

您现在的位置是:首页 >  后端

当前栏目

Python 列表(List)详解编程语言

2023-06-13 09:11:48 时间

序列是Python中最基本的数据结构。序列中的每个元素都分配一个数字 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推。

Python有6个序列的内置类型,但最常见的是列表和元组。

序列都可以进行的操作包括索引,切片,加,乘,检查成员。

此外,Python已经内置确定序列的长度以及确定最大和最小的元素的方法。

列表是最常用的Python数据类型,它可以作为一个方括号内的逗号分隔值出现。

列表的数据项不需要具有相同的类型

创建一个列表,只要把逗号分隔的不同的数据项使用方括号括起来即可。如下所示:


list1 = [ physics , chemistry , 1997, 2000] list2 = [1, 2, 3, 4, 5 ] list3 = [ a , b , c , d ]

与字符串的索引一样,列表索引从0开始。列表可以进行截取、组合等。

访问列表中的值

使用下标索引来访问列表中的值,同样你也可以使用方括号的形式截取字符,如下所示:

实例(Python 2.0+)
#!/usr/bin/python list1 = [ physics , chemistry , 1997, 2000] list2 = [1, 2, 3, 4, 5, 6, 7 ] print list1[0]: , list1[0] print list2[1:5]: , list2[1:5]

以上实例输出结果:

list1[0]: physics 

list2[1:5]: [2, 3, 4, 5] 

你可以对列表的数据项进行修改或更新,你也可以使用append()方法来添加列表项,如下所示:

实例(Python 2.0+)
#!/usr/bin/python # -*- coding: UTF-8 -*- list = [] ## 空列表 list.append( Google ) ## 使用 append() 添加元素 list.append( Runoob ) print list

注意:我们会在接下来的章节讨论append()方法的使用

以上实例输出结果:

[Google, Runoob] 

删除列表元素

可以使用 del 语句来删除列表的元素,如下实例:

实例(Python 2.0+)
#!/usr/bin/python list1 = [ physics , chemistry , 1997, 2000] print list1 del list1[2] print After deleting value at index 2 : print list1

以上实例输出结果:

[physics, chemistry, 1997, 2000] 

After deleting value at index 2 : 

[physics, chemistry, 2000] 

注意:我们会在接下来的章节讨论remove()方法的使用

Python列表脚本操作符

列表对 + 和 * 的操作符与字符串相似。+ 号用于组合列表,* 号用于重复列表。

如下所示:


其他:

python 创建二维列表,将需要的参数写入 cols 和 rows 即可

list_2d = [[0 for col in range(cols)] for row in range(rows)]
实例:

list_2d = [ [0 for me in range(5)] for me in range(5)]
list_2d[0].append(3)
list_2d[0].append(5)
list_2d[2].append(7)
list_2d
[[0, 0, 0, 0, 0, 3, 5], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 7], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]


#!/usr/bin/python
# -*- coding: UTF-8 -*-

list01 = [runoob, 786, 2.23, john, 70.2]
list02 = [123, john]

print list01
print list02

# 列表截取

print list01[0]
print list01[-1]
print list01[0:3]

# 列表重复

print list01 * 2

# 列表组合

print list01 + list02

# 获取列表长度

print len(list01)

# 删除列表元素

del list02[0]
print list02

# 元素是否存在于列表中

print john in list02 # True

# 迭代

for me in list01:
print me

# 比较两个列表的元素

print cmp(list01, list02)

# 列表最大/最小值

print max([0, 1, 2, 3, 4])
print min([0, 1])

# 将元组转换为列表

aTuple = (1,2,3,4)
list03 = list(aTuple)
print list03

# 在列表末尾添加新的元素

list03.append(5)
print list03

# 在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)

list03.extend(list01)
print list03

# 统计某个元素在列表中出现的次数

print list03.count(1)

# 从列表中找出某个值第一个匹配项的索引位置

print list03.index(john)

# 将对象插入列表

list03.insert(0, hello)
print list03

# 移除列表中的一个元素(默认最后一个元素),并且返回该元素的值

print list03.pop(0)
print list03

# 移除列表中某个值的第一个匹配项

list03.remove(1)
print list03

# 反向列表中元素

list03.reverse()
print list03

# 对原列表进行排序

list03.sort()
print list03
python list
python list


list4=[123,["das","aaa"],234]
list4
"aaa" in list4 #in只能判断一个层次的元素
False
"aaa" in list4[1] #选中列表中的列表进行判断
True
list4[1][1]
aaa

遍历嵌套的列表:

num_list = [[1,2,3],[4,5,6]]
for me in num_list:
for j in me:
print(j)
输出结果:

1
2
3
4
5
6

[:-1] 表示从第一个元素遍历到倒数第二个元素:

# -*- coding: UTF-8 -*-

list1 = [1,2,3,4,5,]

print list1

# 列表截取
print list1[:-1]
输出结果:

[1, 2, 3, 4, 5]
[1, 2, 3, 4]

列表里 a 与 a[:] 不同。

我们可以通过函数 id() 来查看:

a = [1, 2, 3]
id(a)
id(a[:])
会发现得到的两个值不同。

或者直接运行:

a is a[:]
返回值将是:False。

简单来说,a[:]是创建a的一个副本,这样我们在代码中对a[:]进行操作后,就不会改变a的值了。而若直接对a进行操作,那么a的值会收到一些操作的影响,如append()等。
针对列表无法正常输出汉字的解决方法:

#encoding=utf-8

import json

list_words = [ 你, 我, 他 ]
print( list_words ) # 无法正常显示汉字
print( str(list_words).decode( string_escape ) ) # 正常显示汉字

list_words_result = json.dumps( list_words, encoding=UTF-8, ensure_ascii=False )
print( list_words_result )
输出结果为:

[/xe4/xbd/xa0, /xe6/x88/x91, /xe4/xbb/x96]
[你, 我, 他]
["你", "我", "他"]


remove 和 del 之间的区别:

a=[1,2,3,5,4,2,6]
a.remove(a[5])
a
[1, 3, 5, 4, 2, 6]
说明 remove 移除的是列表中元素的位置。

a=[1,2,3,5,4,2,6]
del(a[5])
a
[1, 2, 3, 5, 4, 6]
说明 del 删除是按索引来的,索引起始位置为 0。

清空列表中的多项空值:

test = [a,,b,,c,,]
test = [me for me in test if me != ]

print(test)
输出结果为:

[a, b, c]

Python 列表切片应用

# -*- coding: UTF-8 -*-

s = abcdefg
# 返回从起始位置到索引位置 2 处的字符串切片
print(s[:3]) # 输出 abc

# 返回从第三个索引位置到结尾的字符串切片
print(s[3:]) # 输出 defg

# 字符串逆序输出
print(s[::-1]) # 输出 gfedcba

# 输出从开始位置间隔一个字符组成的字符串
print(s[::2]) # 输出 aceg
print(range(10)[::2]) # 输出偶数:[0, 2, 4, 6, 8]

# 它们也可以相互结合使用。
# 从索引位置 6 到索引位置 2,逆向间隔一个字符
print(s[6:2:-2]) # 输出ge


Python 数组的步长操作:

a = [0,2,3,4,5,6,7,8,22,44,55]

# 2 表示起始坐标,10 表示终止坐标,3 表示步长,即每移动 3 个位置取值
b = a[2:10:3]
print(b)
输出结果为:

[3, 6, 22]


列表解析 List Comprehensions

表达式:[expression for iter_val in iterable if cond_expr]
[expression]:最后执行的结果
[for iter_val in iterable]:这个可以是一个多层循环
[if cond_expr]:两个for间是不能有判断语句的,判断语句只能在最后;顺序不定,默认是左到右。
讨论下多个 for 循环的执行顺序。


从左到右:

print[(x,y)for x in [1,2]for y in [3,4]]
[(1, 3), (1, 4), (2, 3), (2, 4)]
print[(x,y)for x in [1,2]for y in [3,x]]
[(1, 3), (1, 1), (2, 3), (2, 2)]

从右到左:

print[(x,y)for x in [1,y]for y in [3,4]]
[(1, 3), (1, 4), (2, 3), (2, 4)]



资料来源:IT虾米网

17749.html

cgojavapython