#Python# 二维数组的定义、使用的几种方法
通常的困扰
之前对Python里面创建、使用二维数组也很懵,于是也上网查了一些讲解,也发现一些类似的问题,大多数存在着 以为定义正确了二维数组,但修改数据的时候,发现数据经常一起串改。如:
b=[[0,0,0]]*3
b[0][1]=1 #这里因为初始[0,0,0]可以这样写数据,如果初始空数组则不能
print(b)
b[1].append(3)
print(b)
输出:
[[0, 1, 0], [0, 1, 0], [0, 1, 0]]
[[0, 1, 0, 3], [0, 1, 0, 3], [0, 1, 0, 3]]
因为像这种*3操作,其数据在三个数组里会被一起改掉。
1、先介绍最简单的一种方式
因为Python的数组本身就是动态可变的,同时提供append()函数,该函数不仅可以在一个数组后面添加数字,也可以在后面任意添加数组,如:
c = []
c.append([1,2,3,4])
c.append([5,6,7,8])
c.append(9)
print(c)
最后输出为:
[[1, 2, 3, 4], [5, 6, 7, 8], 9]
该种方法在 已建立 了的数组基础上可以通过c[ i ][ j ]的方式对数据修改和读取:
c[0][1]=10
输出为:
[[1, 10, 3, 4], [5, 6, 7, 8], 9]
2、再介绍最常见的一种方式
b=[[] for i in range(4)]
b[0].append(5)
b[1].append(6)
print(b)
最后输出为:
[[5], [6], [ ], [ ]]
该种方法在最大的好处在于通过b[ i ]来存储二维数据,更加直观和清晰。但需先已知数据行数,这里是四行数据。
但一旦对数据没有通过append()方式添加,而是在位置上直接赋值如:
b=[[] for i in range(4)]
b[0]=5
b[1].append(6)
print(b)
最后输出为:
[5, [6], [ ], [ ]]
看输出就知道对于b[1] 以后就只能是一个数字5,不能再在此位置存储数据。
3、最后介绍最暴力直观的一种方式
a=[[[]for i in range(3)]for i in range(4)]
最后输出为:
[[[], [], []], [[], [], []], [[], [], []], [[], [], []]]
显然建立了四行三列的矩阵,且每个位置上也是数组的形式,如果比较习惯于通过a[i][j]这样的方式来存储读取数据,这种方式很适合,同时也可以在 未建立 数据(即还没有实际数据)的基础上,也能通过c[ i ][ j ]的方式存储修改数据。弊端是要先知道行列数。如果完全了解上面两种方式的话,这种建立二维数组方式感觉很没必要。
a=[[[]for i in range(3)]for i in range(4)]
a[0][0]=1
a[0][1].append(2)
print(a)
最后输出为:
[[1, [2], []], [[], [], []], [[], [], []], [[], [], []]]
这里我们就可以看到直接赋值和append()函数的差别。