当前位置: 首页 > wzjs >正文

创意福州网站建设快速网站轻松排名

创意福州网站建设,快速网站轻松排名,连云港网站建设推广,做课展网站NumPy数组访问 索引访问切片访问布尔索引花式索引迭代数组1、默认遍历2、控制顺序行优先列优先 3、读写模式4、其他参数 广播迭代1、标量与一维数组2、标量与二维数组3、二维数据与一维数组4、列向量与行向量相加5、二维数据与二维数组 索引访问 通过下标来访问数据元素&#x…

NumPy数组访问

  • 索引访问
  • 切片访问
  • 布尔索引
  • 花式索引
  • 迭代数组
    • 1、默认遍历
    • 2、控制顺序
      • 行优先
      • 列优先
    • 3、读写模式
    • 4、其他参数
  • 广播迭代
    • 1、标量与一维数组
    • 2、标量与二维数组
    • 3、二维数据与一维数组
    • 4、列向量与行向量相加
    • 5、二维数据与二维数组

索引访问

通过下标来访问数据元素,当总数不知道的时候,使用负值索引就很方便,特别是切片访问的时候

数组值北京上海广州深圳
正值索引0123
负值索引0-3-2-1
a = np.array([1, 2, 3, 4, 5, 6])print("| a[1]", a[1], sep=" | ", end="|\r\n")
print("| a[-1]", a[-1], sep=" | ", end="|\r\n")
print("| a[a.size-1]", a[a.size - 1], sep=" | ", end="|\r\n")

切片访问

1、 [start:end:step] , step可以为负值,start包括,end不包括
2、通过切片返回的数组元素与原数组是一个引用,一改全改

  • start可以省略,不写默认从0开始
  • end可以省略,不写默认到-1结束
  • step可以省略,不写默认是1
a = np.array([1, 2, 3, 4, 5, 6])
print("| a[:3:2]", "[1,3]", a[:3:2], sep=" | ", end="|\r\n")
print("| a[1::2]", "[2,4,6]", a[1::2], sep=" | ", end="|\r\n")
print("| a[::2]", "[1,3,5]", a[::2], sep=" | ", end="|\r\n")
print("| a[::]", "[1,2,3,4,5,6]", a[::], sep=" | ", end="|\r\n")
print("| a[:-2:-2]", "[1,2,3,4,5,6]", a[-2:1:-2], sep=" | ", end="|\r\n")

二维数组切片:

1234
5678
9101112

针对多维维数组,每个轴分别切片,然后取交叉点的元素

  • 行(0轴),0👎1 -> 行0,1
  • 列(1轴),1:4:2 ->列1,3

最终结果是3行2列的数组

a = np.array([(1, 2, 3, 4), (5, 6, 7, 8), (9, 10, 11, 12)])
print(a[0:-1:1, 1:4:2])

布尔索引

1、通过一个布尔数组来索引目标数组
2、布尔数组与原数组形状必须相同
3、返回的新数组与原数组无关,可以随便修改,深层复制
4、返回数据是一个一维数组

一维数组:

a = np.arange(start=1, stop=5, step=1)
b = np.array((True, True, False, False), dtype=np.bool_)
print(a[b])
print(a[a % 2 == 0])

二维数组:

a = np.array([(1, 2, 3), (4, 5, 6)], dtype=np.int32)
b = np.array([(True, False, False), (False, True, True)], dtype=np.bool_)
print(a[b])

花式索引

1、使用整数列表、整数数组作为数组索引
2、新数组的元素属于深层复制,修改不影响原数组

一维数组:

a = np.arange(start=1, stop=10, step=1)
# 整数数组
b = np.array([1, 2, 3])
print(a[b])# 整数列表
ll = [0, 2, 4]
print(a[ll])

二维数组:

123
456
789
  • 0轴索引数组
12
22
  • 1轴索引数组
00
11
  • 结果展示
a[1,0]a[2,0]
a[2,1]a[2,1]
a = np.array([(1, 2, 3), (4, 5, 6), (7, 8, 9)], dtype=np.int32)
# 0轴
d0 = np.array([[1, 2], [2, 2]])
# 1轴
d1 = np.array([[0, 0], [1, 1]])
print(a[d0, d1])[[4 7][8 8]]

迭代数组

使用numpy.nditer访问数组元素

1、默认遍历

a = np.array([(1, 2, 3), (4, 5, 6), (7, 8, 9)], dtype=np.int32)
for x in np.nditer(a):print(x, end=", ")
print('\n')# 转置
for x in np.nditer(a.T):print(x, end=", ")
print('\n')

2、控制顺序

行优先

a = np.array([(1, 2, 3), (4, 5, 6), (7, 8, 9)], dtype=np.int32)# C order,即是行序优先
for x in np.nditer(a, order='C'):print(x, end=", ")
print('\n')

列优先

a = np.array([(1, 2, 3), (4, 5, 6), (7, 8, 9)], dtype=np.int32)# Fortran order,即是列序优先
for x in np.nditer(a, order='F'):print(x, end=", ")
print('\n')

3、读写模式

op_flags参数,默认read-only,可以设置readwrite writeonly

# 遍历中修改
a = np.array([(1, 2, 3), (4, 5, 6), (7, 8, 9)], dtype=np.int32)for x in np.nditer(a, op_flags=['readwrite']):x[...] = 2 * x
print('修改后的数组是:')
print(a)

4、其他参数

flags参数

参数描述
c_index可以跟踪 C 顺序的索引
f_index可以跟踪 Fortran 顺序的索引
multi_index每次迭代可以跟踪一种索引类型
external_loop给出的值是具有多个值的一维数组,而不是零维数组
a = np.array([(1, 2, 3), (4, 5, 6), (7, 8, 9)], dtype=np.int32)
it = np.nditer(a, flags=['f_index'])
for x in it:print('index:{0}, value:{1}'.format(it.index, x))
print("\n")it = np.nditer(a, flags=['c_index'])
for x in it:print('index:{0}, value:{1}'.format(it.index, x))
print("\n")it = np.nditer(a, flags=['multi_index'])
for x in it:print('index:{0}, value:{1}'.format(it.multi_index, x))
print("\n")for x in np.nditer(a, flags=['external_loop'], order='F'):print(x, end='\n')
print("\n")

广播迭代

1、数组拥有相同形状
2、当前维度的值相等
3、当前维度的值有一个是 1

1、标量与一维数组

标量与每一个元素相加

a = np.array([1, 2, 3])
b = a + 5
print(b)[6 7 8]

2、标量与二维数组

标量与每一个元素相加

a = np.array([(1, 2, 3), (4, 5, 6), (7, 8, 9)], dtype=np.int32)
b = a + 5
print(b)[[ 6  7  8][ 9 10 11][12 13 14]]

3、二维数据与一维数组

这里将一维数组拉伸复制,最后对应相加

a = np.array([[1, 2, 3], [4, 5, 6]])
b = np.array([10, 20, 30])result = a + b
print(result)

4、列向量与行向量相加

这里分别将两个一维数组拉伸复制,最后对应相加

a = np.array([[1], [2], [3]])
b = np.array([10, 20, 30])result = a + b
print(result)

5、二维数据与二维数组

这里对应元素相加

a = np.array([(1, 2, 3), (4, 5, 6)], dtype=np.int32)
b = np.array([(10, 20, 30), (40, 50, 60)], dtype=np.int32)
print(a + b)
http://www.dtcms.com/wzjs/348954.html

相关文章:

  • 烟台建设网站西安官网seo
  • 中关村网站建设线下推广方案
  • 建设银行网站app查卡号指数函数求导
  • 个人站长怎么样做网站才不会很累百度新闻网
  • 深圳网站制作品牌祥奔科技seo 是什么
  • 文案策划网站重庆百度小额贷款有限公司
  • 太原网站设计公司外贸全网营销推广
  • 南京网站建设公司开发seo管理系统创作
  • 做网站必须有云虚拟主机百度数据库
  • 重庆信息门户网站网络服务器的功能
  • 优惠网站怎么做百度客服人工电话24
  • wish网站应该怎么做买号链接
  • 网络营销成功案例有哪些2022揭阳百度seo公司
  • 专业网站建设教程网络推广常见的方法
  • 中建国际建设有限公司网站厦门人才网官方网站
  • 洛阳建站推广公司企业网站建设的作用
  • wordpress站点管理自动优化句子的软件
  • 香港ip做外贸网站sem分析是什么意思
  • 视频网站怎么做统计表简述如何优化网站的方法
  • 链接网站logo网站建设介绍ppt
  • 网站后台权限分配说明百度云盘资源共享链接群组链接
  • 已有域名怎么建设网站如何在手机上建立自己的网站
  • 哪里有做彩票网站了网站应该如何进行优化
  • weex做网站免费发布推广信息网站
  • 嵌入式培训宣传seo搜索引擎优化试题及答案
  • 网站群如何做网站网络营销培训
  • iis创建网站百度竞价排名查询网站
  • 网站建设企业排行榜百度seo报价方法
  • 帝国建设网站网站分析
  • 长沙网络公司seo技术是什么意思