OpenCV||超简略的Numpy小tip

一、基本类型

二、数组属性

三、数组迭代(了解)

复制代码
import numpy as np  
  
# 创建一个数组  
a = np.arange(6).reshape(2, 3)  
  
# 使用np.nditer遍历数组  
for x in np.nditer(a):  
    print(x)

np.nditer有多个参数,用于控制迭代器的行为,以下是一些重要参数的介绍:

  1. op:要迭代的数组或数组序列。

  2. flags :一个字符串列表,用于控制迭代器的行为。例如,'buffered''c_index''f_index''multi_index'等。这些标志可以组合使用,以满足不同的迭代需求。

    • 'buffered':启用缓冲,以减少内存访问次数。
    • 'c_index':跟踪C顺序索引。
    • 'f_index':跟踪Fortran顺序索引。
    • 'multi_index':跟踪多个索引或每个迭代维度一个索引元组。
  3. op_flags :一个字符串列表,用于指定每个操作数的标志。常用的有'readonly''readwrite''writeonly'

    • 'readonly':表示只读取操作数。
    • 'readwrite':表示将读取和写入操作数。
    • 'writeonly':表示只会写入操作数。
  4. op_dtypes:一个数据类型或数据类型元组,用于指定操作数所需的数据类型。如果启用了复制或缓冲,则数据将转换为指定的类型。

  5. order :控制迭代顺序,可选'C'(C顺序)、'F'(Fortran顺序)或'A'(如果所有数组都是Fortran连续的,则为'F'顺序,否则为'C'顺序)。

  6. casting :控制进行复制或缓冲时可能出现的数据转换类型。可选值包括'no''equiv''safe''same_kind''unsafe'

高级用法:

复制代码
# 同时迭代多个数组  
a = np.arange(6).reshape(2, 3)  
b = np.array([[1, 2, 3], [4, 5, 6]])  
  
# 使用multi_index同时获取索引和元素值  
it = np.nditer([a, b], flags=['multi_index'], op_flags=['readonly'])  
while not it.finished:  
    print(it.multi_index, it[0], it[1])  
    it.iternext()

四、写在最后

学习OpenCV前,扎实的Numpy基础是不容忽视的。

链接跳转:

章节一、OpenCV||超细节的基本操作

章节三、OpenCV||超详细的图像处理模块

章节四、OpenCV||超详细的灰度变换和直方图修正

章节五、OpenCV||超详细的图像平滑

章节六、OpenCV||超详细的几何变换

相关推荐
静心问道2 小时前
SqueezeBERT:计算机视觉能为自然语言处理在高效神经网络方面带来哪些启示?
人工智能·计算机视觉·自然语言处理
顾道长生'9 小时前
(Arxiv-2025)通过动态 token 剔除实现无需训练的高效视频生成
计算机视觉·音视频·视频生成
GG不是gg12 小时前
NumPy-核心函数np.dot()深入理解
numpy
shangyingying_113 小时前
关于小波降噪、小波增强、小波去雾的原理区分
人工智能·深度学习·计算机视觉
要努力啊啊啊15 小时前
YOLOv2 正负样本分配机制详解
人工智能·深度学习·yolo·计算机视觉·目标跟踪
好开心啊没烦恼19 小时前
Python 数据分析:numpy,抽提,整数数组索引与基本索引扩展(元组传参)。听故事学知识点怎么这么容易?
开发语言·人工智能·python·数据挖掘·数据分析·numpy·pandas
BIYing_Aurora19 小时前
【IPMV】图像处理与机器视觉:Lec13 Robust Estimation with RANSAC
图像处理·人工智能·算法·计算机视觉
CHANG_THE_WORLD20 小时前
封装一个png的编码解码操作
图像处理·人工智能·计算机视觉
云天徽上20 小时前
【PaddleOCR】OCR常见关键信息抽取数据集,包含FUNSD、XFUND、WildReceipt等整理,持续更新中......
人工智能·计算机视觉·信息可视化·paddlepaddle·paddleocr·文本识别
lx7416026981 天前
cd-agent更换cd模型(自用)
计算机视觉