草庐IT

【numpy笔记_4】索引、高级索引和切片

fakeProgramer 2023-09-28 原文

得益于模块功能的强大,numpy的索引方式玩得很花,索引也分为常规索引和高级索引,花式索引。

numpy的索引和切片逻辑与list十分相似,基本都以index为基。

之前提到结构化数组通过"name"的方式索引,有点像pandas的列名索引,这里先不多提,整体也好理解。

你可能猜到了,numpy的索引同样从零开始。

先把索引操作放一边,尝试理解它的逻辑:

虽然探究numpy的源代码并不容易,我们试着把概念抽象出来,换个视角看看。

我们把array对象可以看作线、面、体的嵌套形结构,索引与结构一一对应。就像这样:
数组结构与索引的关系.png

这种数组结构与索引的对应关系非常鲜明,让我们看清索引是怎样一步步定位到值的。再结合几个例子看一下:

import numpy as np
datas = [1,2,3,4,5,6,7,8,9,10,11,12]
array_1d = np.array(datas)   # 线
array_2d = np.array(datas).reshape((4,3))   # 面
array_3d = np.array(datas).reshape((2,3,2))   # 体

print(array_1d)
print(array_1d[1:3])  # 还是左闭右开的切片  ******  第2个到第4个(不含)
# 运行结果:
[ 1  2  3  4  5  6  7  8  9 10 11 12]   # 原数组
[2 3]   # 结果(切片)

print(array_2d)
print(array_2d[1])   # 取整行  ******  第2行
# 运行结果:
[[ 1  2  3]
 [ 4  5  6]
 [ 7  8  9]
 [10 11 12]]    # 原数组
[4 5 6]   # 结果(取整行)

print(array_3d)
print(array_3d[1, 0, 0])   # 取值  ******  第2个,第1行,第1个
print(array_3d[1, 2, :])     # 取行的某段  ******  第2个,第3行,全部切片
print(array_3d[1, 1])     # 取整行  ******  第2个,第2行
# 运行结果:
[[[ 1  2]
  [ 3  4]
  [ 5  6]]

 [[ 7  8]
  [ 9 10]
  [11 12]]]    # 原数组
7    # 结果(取值)
[11 12]    # 结果(取行的某段)
[ 9 10]    # 结果(取整行)

理解到这里,恭喜你已经掌握了索引、切片、多维切片、高级索引的大部分知识点。再看几个例子补充完剩下的:

import numpy as np
datas = [1,2,3,4,5,6,7,8,9,10,11,12]
array_1d = np.array(datas)   # 线
array_2d = np.array(datas).reshape((4,3))   # 面

print(array_1d)
print(array_1d[:9:2])  # 切片操作,(起:止:步长)
print('* '*20)
print(array_2d)
print(array_2d[[1,3],[0,2]])   # 整数数组索引。前后分别是行/列,索引一一对应,相当于(1,0)和(3,2)的意思
print(array_2d[array_2d > 5])   # 布尔索引。找到True的位置对应的值
print(array_2d[[1,2,3]])   # 花式索引。取第2行,第3行,第4行(要用中括号包住,否则意思就变成了在2d数组里找体、行、列)
# 运行结果:
[ 1  2  3  4  5  6  7  8  9 10 11 12]

[1 3 5 7 9]
* * * * * * * * * * * * * * * * * * * * 
[[ 1  2  3]
 [ 4  5  6]
 [ 7  8  9]
 [10 11 12]]

[ 4 12]

[ 6  7  8  9 10 11 12]

[[ 4  5  6]
 [ 7  8  9]
 [10 11 12]]

numpy的索引就到这里。

下篇内容会介绍numpy里的广播机制。
等理解完前面这些知识点,后面的进度就会快一些。

有关【numpy笔记_4】索引、高级索引和切片的更多相关文章

  1. LC滤波器设计学习笔记(一)滤波电路入门 - 2

    目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称

  2. ruby-on-rails - 协会的 Rails 索引 - 2

    我发现自己需要这个。假设cart是一个包含用户列表的模型。defindex_of_itemcart.users.each_with_indexdo|u,i|ifu==current_userreturniendend获取此类关联索引的更简单方法是什么? 最佳答案 indexArray上的方法与您的index_of_item方法相同,例如cart.users.index(current_user)返回数组中第一个对象的索引==给obj。如果未找到匹配项,则返回nil。 关于ruby-on-

  3. ruby - Rails -- :id attribute? 所需的数据库索引 - 2

    因此,当我遵循MichaelHartl的RubyonRails教程时,我注意到在用户表中,我们为:email属性添加了一个唯一索引,以提高find的效率方法,因此它不会逐行搜索。到目前为止,我们一直在根据情况使用find_by_email和find_by_id进行搜索。然而,我们从未为:id属性设置索引。:id是否自动索引,因为它在默认情况下是唯一的并且本质上是顺序的?或者情况并非如此,我应该为:id搜索添加索引吗? 最佳答案 大多数数据库(包括sqlite,这是RoR中的默认数据库)会自动索引主键,对于RailsMigration

  4. ruby - 引用具有指定索引的枚举器值 - 2

    假设我有一个可枚举对象enum,现在我想获取第三个项目。我知道一种通用方法是转换成数组,然后使用索引访问,如:enum.to_a[2]但这种方式会创建一个临时数组,效率可能很低。现在我使用:enum.each_with_index{|v,i|breakvifi==2}但这非常丑陋和多余。执行此操作最有效的方法是什么? 最佳答案 你可以使用take剥离前三个元素,然后剥离last从take给你的数组中获取第三个元素:third=enum.take(3).last如果您根本不想生成任何数组,那么也许:#Ifenumisn'tanEnum

  5. ruby-on-rails - Ruby on Rails 将列表拆分或切片为列 - 2

    @locations=Location.all#currentlistingall@locations=Location.slice(5)orLocation.split(5)使用Ruby,我试图将我的列表分成4列,每列限制为5个;然而,切片或拆分似乎都不起作用。知道我可能做错了什么吗?任何帮助是极大的赞赏。 最佳答案 您可能想使用in_groups_of:http://railscasts.com/episodes/28-in-groups-of这是RyanBates在railscast中的示例用法:

  6. ruby - 将 Logstash 中的时间戳时区转换为输出索引名称 - 2

    在我的场景中,Logstash收到的系统日志行的“时间戳”是UTC,我们在Elasticsearch输出中使用事件“时间戳”:output{elasticsearch{embedded=>falsehost=>localhostport=>9200protocol=>httpcluster=>'elasticsearch'index=>"syslog-%{+YYYY.MM.dd}"}}我的问题是,在UTC午夜,Logstash在外时区(GMT-4=>America/Montreal)结束前将日志发送到不同的索引,并且索引在20小时(晚上8点)之后没有日志,因为“时间戳”是UTC。我们已

  7. ruby - 从特定索引开始迭代数组 - 2

    我想从特定索引开始遍历数组。我该怎么做?myj.eachdo|temp|...end 最佳答案 执行以下操作:your_array[your_index..-1].eachdo|temp|###end 关于ruby-从特定索引开始迭代数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/44151758/

  8. ruby - Array of Arrays,根据索引处的数组内容删除一个索引? - 2

    我一直在努力学习如何处理由数组组成的数组。假设我有这个数组:my_array=[['ORANGE',1],['APPLE',2],['PEACH',3]我将如何找到包含'apple'的my_array索引并删除该索引(删除子数组['APPLE',2]因为'apple'包含在该索引的数组中)?谢谢-我非常感谢这里的帮助。 最佳答案 您可以使用Array.select过滤掉项目:>>a=[['ORANGE',1],['APPLE',2],['PEACH',3]]=>[["ORANGE",1],["APPLE",2],["PEACH",3

  9. ruby - 如何使用部分字符串搜索数组并返回索引? - 2

    我想使用部分字符串搜索数组,然后获取找到该字符串的索引。例如:a=["Thisisline1","Wehaveline2here","andfinallyline3","potato"]a.index("potato")#thisreturns3a.index("Wehave")#thisreturnsnil使用a.grep将返回完整的字符串,使用a.any?将返回正确的true/false语句,但都不会返回匹配的索引找到了,或者至少我不知道该怎么做。我正在编写一段代码,该代码读取文件、查找特定header,然后返回该header的索引,以便它可以将其用作future搜索的偏移量。如果

  10. ruby-on-rails - Rails 4 从迁移索引中删除迁移 ID - 2

    如何在rakedb:migrate:status中删除带有“**NOFILE**”的迁移ID列表?例如:StatusMigrationIDMigrationName--------------------------------------------------up20131017204224Createusersup20131218005823**********NOFILE**********up20131218011334**********NOFILE**********我不明白为什么当我自己手动删除它时它仍然保留旧的迁移文件,因为我正在研究迁移的工作原理。这是为了记录吗?但

随机推荐