关于python中ndarray数组索引的使用方法
在python中,索引和切片相当于是对数组中内容的读或者查询。是我们获取有用信息的重要方法。

对于1维数组:在数组名的后面用中括号[]包括索引编号,括号中填写所查询数组的编码。比如:data[1]
对于n维数组:有两种方式。第一种:用列表表示所查询数的坐标值,如data_2dim[1,0]。第二种:把多维数组看成一位数组套娃,依次取值,如data_2dim[1][0]。
关于python中ndarray数组切片的使用方法
对于1维数组:在数组名后加上中括号[],在括号中填写切片的范围,m:n注意这个式子用冒号作为分隔符,表示的意义是m≤index<n,如:data[2:4]。特别要注意的是m和n如果省略了,则默认m=0,n=length(array),也就是说默认是第一位和最后一位。这个和matlab中的冒号表达式是不一样的。
对于n维数组:把多维数组看成一位数组套娃,依次取值,要注意的是,多维数组的切片往往还是多维数组,如果需要得到具体某一个元素,则在切片之后还要进行索引操作。
可以在以下代码中演示索引和切片操作:
import numpy as np
data = np.array([0,1,2,3,4,5])
print(data[1])
print(data[2:4])
data_2dim = np.array([[1,2,3],[4,5,6],[7,8,9],[10,11,12]])
print(data_2dim[1,0])
print(data_2dim[1][0])
print(data_2dim[1:4])
print(data_2dim[1:4][1:3][1][2])
运行结果如下:
1
[2 3]
4
4
[[4 5 6]
[7 8 9]
[10 11 12]]
12
特别要注意的是切片存放的变量和原来的数组变量在本质上共享同一片内存,如果修改了切片存放的变量,那么原来的数组的对应元素也会对应修改。
如果需要在修改切片的同时不改变原来数组中的数据,可以使用.copy()方法。
data=np.arange(10)
data_slice=data[3:6].copy()
print(data)
print(data_slice)
data_slice[2]=100
print(data)
print(data_slice)
运行结果如下:
[0 1 2 3 4 5 6 7 8 9]
[3 4 5]
[0 1 2 3 4 5 6 7 8 9]
[ 3 4 100]
总结
索引和切片都是对数组读的操作,都使用方括号[](square bracket)进行编号的框定。值得特别注意的是,多维数组的切片往往还是多维数组,如果需要得到具体某一个元素,则在切片之后还要进行索引操作。同时,切片存放的变量和原来的数组变量在本质上共享同一片内存,如果修改了切片存放的变量,那么原来的数组的对应元素也会对应修改。
希望这篇文章可以对大家更好地理解numpy中ndarray数组索引和切片的使用方法有所帮助。
原创文章,作者:小编小本本,如若转载,请注明出处:https://www.benjiyun.com/yunzhujiyunwei/vps-yunwei/7297.html
