利用OpenCV的函数imwrite()保存图像到硬盘

article/2025/10/3 9:06:16

在图像处理的操作中,我们不仅要经常显示图像,还需要保存图像到硬盘或其它存储设备,可以利用函数imwrite()实现。

函数imwrite()的原型如下:
C++原型:

bool cv::imwrite(const String & filename,InputArray img,const std::vector< int > & params = std::vector< int >())

Python原型:

	retval=cv.imwrite(filename, img[, params])

参数filename表示写入硬盘文件的路径、文件名和扩展名。

参数img表示待写入的源图像。

参数params是可选参数表示图片保存时的一些属性设置。
默认情况下将图像保存为8位数据深度的单通道图像或BGR图像。

  • 当图像的数据深度比较特殊时,可以设置这个参数进行相关保存。 不同数据类型的图像能够保存的格式如下:
  • 数据类型为unit16(即(CV_16U)的图像可以保存为PNG、JPEG、TIFF格式文件。
  • 数据类型为float32的图像可以保存成PFM、TIFF、OpenEXR、和Radiance HDR格式文件。

参数params还可以设置JPEG图像的质量、PNG的压缩级别等。
参数params的所有可取值和意义大家可参见下面这个官方链接:
https://docs.opencv.org/4.4.0/d4/da8/group__imgcodecs.html#ga292d81be8d76901bff7988d18d2b42ac

示例代码:
C++代码如下:

//出处:昊虹AI笔记网(hhai.cc)
//用心记录计算机视觉和AI技术//博主微信/QQ 2487872782
//QQ群 271891601
//欢迎技术交流与咨询//OpenCV版本 OpenCV3.0#include <opencv2/opencv.hpp>
#include <iostream>using namespace cv;int main()
{Mat src_image = imread("F:/material/images/2022/2022-10/bxf_small.jpg");imwrite("F:/img_output/bxf_small_output.jpg", src_image);waitKey();return(0);
}

Python代码如下:

# -*- coding: utf-8 -*-
# 出处:昊虹AI笔记网(hhai.cc)
# 用心记录计算机视觉和AI技术# 博主微信/QQ 2487872782
# QQ群 271891601
# 欢迎技术交流与咨询# OpenCV的版本为4.4.0import cv2 as cvsrc_image = cv.imread('F:/material/images/2022/2022-10/bxf_small.jpg')
cv.imwrite("F:/img_output/bxf_small_output.jpg", src_image);cv.waitKey(0)
cv.destroyAllWindows()

上面代码运行完成后,在文件夹 F:/img_output/ 下生成了一幅名为 bxf_small_output.jpg 的图像,截图如下:
在这里插入图片描述


http://chatgpt.dhexx.cn/article/qIhZbwSP.shtml

相关文章

Matlab中imwrite函数使用

目录 语法 说明 示例 将灰度图像写入 PNG 将索引图像数据写入 PNG 用 MATLAB 颜色图写入索引图像 将真彩色图像写入 JPEG 将多个图像写入 TIFF 文件 写入 GIF 动画 imwrite函数的作用是将图像写入图形文件。 语法 imwrite(A,filename) imwrite(A,map,filename) imwr…

【OpenCV 例程300篇】02. 图像的保存(cv2.imwrite)

专栏地址&#xff1a;『youcans 的 OpenCV 例程300篇 - 总目录』 01. 图像的读取&#xff08;cv2.imread&#xff09; 02. 图像的保存&#xff08;cv2.imwrite&#xff09; 03. 图像的显示&#xff08;cv2.imshow&#xff09; 04. 用 matplotlib 显示图像&#xff08;plt.imsho…

python-opencv第二期:imwrite函数详解

概要&#xff1a;众嗦粥之所周知&#xff0c;在如今计算机视觉&#xff08;Computer Version short for CV&#xff09;是人工智能与机器人技术发展的一个重大研究方向&#xff0c;而opencv作为一个专门为计算机视觉编程提供技术与函数支持的第三方库&#xff0c;自然是一个需要…

mongodb自增主键ObjectID

一、了解mongodb的ObjectID MongoDB的文档固定是使用“_id”作为主键的&#xff0c;它可以是任何类型的&#xff0c;默认是个ObjectId对象&#xff08;在Java中则表现为字符串&#xff09;&#xff0c;那么为什么MongoDB没有采用其他比较常规的做法&#xff08;比如MySql的自增…

java 生成objectid_算法~位运算ObjectId生成时的秒用

位运算控制数字范围 通过位运算&#xff0c;可以对一个数进行限制&#xff0c;保证这个数在2n-1(3,7,15,31,63,127,255...)范围内&#xff0c;当大于指定的数时&#xff0c;会取这个0到2n-1里的某个数&#xff0c;不会让它溢出。 之前我写过的位运算的文章 本文在ObjectId里的应…

mongodb objectid java_我可以确定字符串是否是MongoDB ObjectID吗?

回答(10) 2 years ago 我发现mongoose ObjectId验证器用于验证有效的objectIds&#xff0c;但我发现了一些无效ID被认为有效的情况 . (例如&#xff1a;任何12个字符长的字符串) var ObjectId require(mongoose).Types.ObjectId; ObjectId.isValid(microsoft123); //true Obje…

MongoDB 认识ObjectId

官方文档&#xff1a;https://docs.mongodb.com/manual/reference/method/ObjectId/ 现在我们有一个集合如下 db.class0.insertMany([{"name": "一年级一班","headmaster": "王老师"},{"name": "一年级二班",&q…

mysql objectid_【Mongodb】_id和ObjectId详解!

2.6.6 _id和ObjectId MongoDB 中存储的文档必须有一个"_id" 键。这个键的值可以是任何类型的&#xff0c;默认是个ObjectId 对象。在一个集合里面&#xff0c;每个文档都有唯一的"_id" 值&#xff0c;来确保集合里面每个文档都能被唯一标识。如果有两个集合…

Mongodb ObjectId格式

ObjectId是一个24位的字符串&#xff0c;实际是由一组十六进制的字符构成&#xff0c;共12个字节。&#xff08;1个字节8位能表示2个十六进制数&#xff0c;12个字节能表示24个十六进制数&#xff09;。 ObjectId 是一个12字节 BSON 类型数据&#xff0c;有以下格式&#xff1a…

java objectid_关于MongoDB ObjectId

ObjectId的构成 ObjectId的值由12个字节组成&#xff0c;其中&#xff0c; 4个字节表示时间戳(自Unix纪元以来的秒数)&#xff0c;记录创建时间&#xff1b; 3个字节表示机器标识符&#xff0c;保证不同主机产生不同的ObjectId值&#xff1b; 2个字节表示进程ID&#xff0c;保证…

从根上理解MongoDB的ObjectId生成原理!

想写这篇文章好久了&#xff0c;一直抽不出时间。这两天端午节放假&#xff0c;我和娃都泡在图书馆&#xff0c;在他看书的空闲期&#xff0c;我拿出电脑写下了本文。 我们都知道&#xff0c;在分布式系统中&#xff0c;分布式 ID 有很多特殊的要求&#xff0c;其中之二就是要求…

ArcGIS中的OBJECTID、FID 和 OID 的区别!不要傻傻分不清

喜欢就关注我们吧 时常有很多我朋友分不清OBJECTID、FID 和 OID有什么区别&#xff0c;不懂得怎么应用和管理&#xff0c;今天我们来说个明白。 ArcGIS Desktop 产品要求独立表和属性表均具有 ObjectID字段&#xff0c;该字段包含唯一的长整型用于标识每个记录。 此 ID 由 Esri…

Mongo中id介绍

好记忆不如按烂笔头 &#xff0c;即便是最简单的&#xff0c;时间长了也难免会忘记&#xff0c;记下可以让你更明白。 2.6.6 _id和ObjectId MongoDB 中存储的文档必须有一个"_id" 键。这个键的值可以是任何类型的&#xff0c;默认是个ObjectId 对象。在一个集合里面…

canal

简介 canal [kənl]&#xff0c;译意为水道/管道/沟渠&#xff0c;主要用途是基于 MySQL 数据库增量日志解析&#xff0c;提供增量数据订阅和消费 早期阿里巴巴因为杭州和美国双机房部署&#xff0c;存在跨机房同步的业务需求&#xff0c;实现方式主要是基于业务 trigger 获取增…

阿里的数据同步神器——Canal

前言 同步数据的神器: Canal安装配置 canal [kə’nl],译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费 早期阿里巴巴因为杭州和美国双机房部署, 存在跨机房同步的业务需求, 实现方式主要是基于业务 trigger 获取增量变更。从 2…

使用Canal组件订阅MySQL binlog数据增量

一、简介 Canal是一款强大的开源组件&#xff0c;主要用途是基于 MySQL 数据库增量日志解析&#xff0c;提供增量数据订阅和消费。 1. canal 工作原理 canal 模拟 MySQL slave 的交互协议&#xff0c;伪装自己为 MySQL slave &#xff0c;向 MySQL master 发送dump 协议MySQ…

mysql进阶:canal搭建主从|集群架构

0.引言 之前我们讲解过canal的各种应用&#xff0c;但是对于生产环境来讲&#xff0c;服务高可用是必须保证的。因此canal单节点是不能满足我们的需求的。就需要搭建canal集群。 1. canal集群模式 从架构方式上出发&#xff0c;我们用来保证服务高可用的手段主要是主从架构、…

ElasticSearch 7.15.2 使用java canal 接入实现灵活化增量数据准实时同步

前言&#xff1a; ①canal.adapter-1.1.5 支持一对一单表的增量数据同步ElasticSearch 7&#xff1b; ②对于多表聚合场景的SQL满足不了我们的业务需求。 ③采用java canal 接入&#xff0c;可以实现灵活化增量数据准实时同步 文章目录 一、java canal 接入1. 依赖导入2. 增加配…

浅入浅出keepalived+mysql实现高可用双机热备

当数据库发生宕机的情况,如果配置了数据库主从同步模式或主主同步模式,则可以从从库中获取数据。 当数据库发生宕机的情况,要求应用系统实现高可用,应用系统不会受到影响,需要对mysql进行双机热备实现数据库的高可用。 实现双机热备的方式有Mycat组件方式、canel组件方式、…

【硬刚大数据】大数据同步工具之FlinkCDC/Canal/Debezium对比

欢迎关注博客主页&#xff1a;微信搜&#xff1a;import_bigdata&#xff0c;大数据领域硬核原创作者_王知无(import_bigdata)_CSDN博客 欢迎点赞、收藏、留言 &#xff0c;欢迎留言交流&#xff01;本文由【王知无】原创&#xff0c;首发于 CSDN博客&#xff01;本文首发CSDN论…