广告位联系
返回顶部
分享到

NumPy迭代数组的实现的介绍

python 来源:互联网 作者:佚名 发布时间:2023-02-20 22:08:57 人浏览
摘要

NumPy中引入了 nditer 对象来提供一种对于数组元素的访问方式。 一、单数组迭代 1. 使用 nditer 访问数组的每个元素 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 a = np.arange(12).reshape(3, 4) for x in np.ndit

NumPy中引入了 nditer 对象来提供一种对于数组元素的访问方式。

一、单数组迭代

1. 使用 nditer 访问数组的每个元素

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

>>>a = np.arange(12).reshape(3, 4)

>>>for x in np.nditer(a):

            print(x, end=' ')

0 1 2 3 4 5 6 7 8 9 10 11 

 

# 以上实例不是使用标准 C 或者 Fortran 顺序,选择的顺序是和数组内存布局一致的,

# 这样做是为了提升访问的效率,默认是行序优先(row-major order,或者说是 C-order)。

# 这反映了默认情况下只需访问每个元素,而无需考虑其特定顺序。

# 我们可以通过迭代上述数组的转置来看到这一点,

# 并与以 C 顺序访问数组转置的 copy 方式做对比,如下实例:

>>>for x in np.nditer(a.T):

            print(x, end=' ')

0 1 2 3 4 5 6 7 8 9 10 11 

 

>>>for x in np.nditer(a.T.copy(order='C')):

            print(x, end=' ')

0 4 8 1 5 9 2 6 10 3 7 11 

2. 控制数组元素的迭代顺序

使用参数 order 控制元素的访问顺序,参数的可选值有:

  • ‘C’:C order,即是行序优先;
  • ‘F’:Fortran order,即是列序优先;
  • ’K’:参考数组元素在内存中的顺序;
  • ‘A’:表示’F’顺序;

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

>>>a = np.arange(12).reshape(3, 4)

>>>for x in np.nditer(a, order='C'):

        print(x, end=' ')

0 1 2 3 4 5 6 7 8 9 10 11 

 

>>>a = np.arange(12).reshape(3, 4)

>>>for x in np.nditer(a, order='F'):

        print(x, end=' ')

0 4 8 1 5 9 2 6 10 3 7 11 

 

>>>a = np.arange(12).reshape(3, 4)

>>>for x in np.nditer(a, order='K'):

        print(x, end=' ')

0 1 2 3 4 5 6 7 8 9 10 11 

 

>>>a = np.arange(12).reshape(3, 4)

>>>for x in np.nditer(a, order='A'):

        print(x, end=' ')

0 1 2 3 4 5 6 7 8 9 10 11 

3. 修改数组值

在使用 nditer 对象迭代数组时,默认情况下是只读状态。因此,如果需要修改数组,可以使用参数 op_flags = 'readwrite' or 'writeonly' 来标志为读写或只读模式。

此时,nditer 在迭代时将生成可写的缓冲区数组,可以在此进行修改。为了在修改后,可以将修改的数据回写到原始位置,需要在迭代结束后,抛出迭代结束信号,有两种方式:

  • 使用 with 上下文管理器;
  • 在迭代结束后,调用迭代器的close方法;

1

2

3

4

5

6

7

8

9

10

11

12

>>>a = np.arange(12).reshape(3, 4)

>>>print(a)

>>>with np.nditer(a, op_flags=['readwrite']) as it:

        for x in it:

            x += 10

>>>print(a)

[[ 0  1  2  3]

 [ 4  5  6  7]

 [ 8  9 10 11]]

[[10 11 12 13]

 [14 15 16 17]

 [18 19 20 21]]

4. 使用外部循环,跟踪索引或多索引

以上操作在迭代过程中,都是逐元素进行的,这虽然简单,但是效率不高。可以使用参数 flags 让 nditer 迭代时提供更大的块。并可以通过强制设定 C 和 F 顺序,得到不同的块大小。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

# 默认情况下保持本机的内存顺序,迭代器提供单一的一维数组

# 'external_loop' 给出的值是具有多个值的一维数组,而不是零维数组

>>>a = np.arange(12).reshape(3, 4)

>>>print(a)

>>>for x in np.nditer(a, flags=['external_loop']):

        print(x, end=' ')

[[ 0  1  2  3]

 [ 4  5  6  7]

 [ 8  9 10 11]]

[ 0  1  2  3  4  5  6  7  8  9 10 11], 

 

# 设定 'F' 顺序

>>>a = np.arange(12).reshape(3, 4)

>>>print(a)

>>>for x in np.nditer(a, flags=['external_loop'], order='F'):

        print(x, end=' ')

[[ 0  1  2  3]

 [ 4  5  6  7]

 [ 8  9 10 11]]

[0 4 8], [1 5 9], [ 2  6 10], [ 3  7 11], 

 

# 'c_index' 可以通过 it.index 跟踪 'C‘ 顺序的索引

>>>a = np.arange(12).reshape(3, 4)

>>>print(a)

>>>it = np.nditer(a, flags=['c_index'])

>>>for x in it:

            print("{}: ({})".format(x, it.index))

[[ 0  1  2  3]

 [ 4  5  6  7]

 [ 8  9 10 11]]

0: (0)

1: (1)

2: (2)

3: (3)

4: (4)

5: (5)

6: (6)

7: (7)

8: (8)

9: (9)

10: (10)

11: (11)

 

# 'f_index' 可以通过 it.index 跟踪 'F‘ 顺序的索引

>>>a = np.arange(12).reshape(3, 4)

>>>print(a)

>>>it = np.nditer(a, flags=['c_index'])

>>>for x in it:

            print("{}: ({})".format(x, it.index))

[[ 0  1  2  3]

 [ 4  5  6  7]

 [ 8  9 10 11]]

0: (0)

1: (3)

2: (6)

3: (9)

4: (1)

5: (4)

6: (7)

7: (10)

8: (2)

9: (5)

10: (8)

11: (11)

 

# 'multi_index' 可以通过 it.multi_index 跟踪数组索引

>>>a = np.arange(12).reshape(3, 4)

>>>print(a)

>>>it = np.nditer(a, flags=['multi_index'])

>>>for x in it:

        print("{}: {}".format(x, it.multi_index))

[[ 0  1  2  3]

 [ 4  5  6  7]

 [ 8  9 10 11]]

0: (0, 0)

1: (0, 1)

2: (0, 2)

3: (0, 3)

4: (1, 0)

5: (1, 1)

6: (1, 2)

7: (1, 3)

8: (2, 0)

9: (2, 1)

10: (2, 2)

11: (2, 3)

external_loop 与 multi_index、c_index、c_index不可同时使用,否则将引发错误 ValueError: Iterator flag EXTERNAL_LOOP cannot be used if an index or multi-index is being tracked

5. 以特定数据类型迭代

当需要以其它的数据类型来迭代数组时,有两种方法:

  • 临时副本:迭代时,会使用新的数据类型创建数组的副本,然后在副本中完成迭代。但是,这种方法会消耗大量的内存空间。
  • 缓冲模式: 使用缓冲来支持灵活输入,内存开销最小。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

# 临时副本

>>>a = np.arange(12).reshape(3, 4)

>>>print(a.dtype)

>>>it = np.nditer(a, op_flags=['readonly', 'copy'],op_dtypes=[np.float64])

>>>for x in it:

        print("{}".format(x), end=', ')

int32

0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0,

 

# 缓冲模式

 

>>>a = np.arange(12).reshape(3, 4)

>>>print(a.dtype)

>>>it = np.nditer(a, flags=['buffered'],op_dtypes=[np.float64])

>>>for x in it:

        print("{}".format(x), end=', ')

int32

0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0, 

注意
默认情况下,转化会执行“安全”机制,如果不符合 NumPy 的转换规则,会引发异常:TypeError: Iterator operand 0 dtype could not be cast from dtype('float64') to dtype('float32') according to the rule 'safe'

二、广播数组迭代

如果不同形状的数组是可广播的,那么 dtype 可以迭代多个数组。

1

2

3

4

5

>>> a = np.arange(3)

>>> b = np.arange(6).reshape(2,3)

>>> for x, y in np.nditer([a,b]):

        print("%d:%d" % (x,y), end=' ')

0:0 1:1 2:2 0:3 1:4 2:5


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/weixin_43276033/article/details/123767613
相关文章
  • JWT的原理及使用
    目录JWT的原理及使用一、什么是JWT?二、签发认证流程三、使用方法1.设置登录接口2.设置过期事件3.定制返回格式4.配置认证类和权限类5.写
  • NumPy迭代数组的实现的介绍
    NumPy中引入了 nditer 对象来提供一种对于数组元素的访问方式。 一、单数组迭代 1. 使用 nditer 访问数组的每个元素 1 2 3 4 5 6 7 8 9 10 11 12 13 1
  • python批量翻译excel表格中的英文
    需求背景 女朋友的论文需要爬取YouTube视频热评,但爬下来的都是外文。 主要设计 读取一个表格文件,获取需要翻译的文本 使用百度翻译
  • python中数字列表转化为数字字符串的代码

    python中数字列表转化为数字字符串的代码
    1. python中数字组成的列表转化为字符串或者一串数字 1 2 3 4 5 6 7 8 f=[1,2,3,4] num=len(f) m= #建立空字符串 for i in range(num): x=str(f[i]) m=m+x #利用字符
  • pandas中groupby操作实现介绍

    pandas中groupby操作实现介绍
    一、实验目的 熟练掌握pandas中的groupby操作 二、实验原理 groupby(by=None, axis=0, level=None, as_index=True, sort=True, group_keys=True, squeeze=False) 参数说明
  • Python正则表达式中group与groups的用法介绍

    Python正则表达式中group与groups的用法介绍
    在Python中,正则表达式的group和groups方法是非常有用的函数,用于处理匹配结果的分组信息。 group方法是re.MatchObject类中的一个函数,用于返
  • Sklearn调优之网格搜索与随机搜索原理介绍
    前言 超参调优是模型调优(Model Tuning)阶段最主要的工作,是直接影响模型最终效果的关键步骤,然而,超参调优本身却是一项非常低级且枯
  • Flask接口签名sign原理与实例代码
    作用 防止有人不停的刷接口,对接口作限制 比如说,登录接口,按道理说,应该只有app会请求这个接口 但是,如果有人抓取app的请求,就
  • Python机器学习利用鸢尾花数据绘制ROC和AUC曲线

    Python机器学习利用鸢尾花数据绘制ROC和AUC曲线
    一、ROC与AUC 很多学习器是为了测试样本产生的一个实值或概率预测,然后将这个预测值与一个分类阈值(threshold)进行比较,若大于阈值则
  • python字符串大小写转换的三种方法

    python字符串大小写转换的三种方法
    python中,为了方便字符串的大小写转换,为我们提供了三种方法: title() lower() upper() python title()方法 title()方法用于将字符串中的每个单词的
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计