邮件发送excel带预览excel功能

news2024/11/22 22:33:29

在这里插入图片描述excel 打开后的内容:
在这里插入图片描述思路:
1、邮件发送excel 是作为附件发送出去的;
2、excel 预览是,必须另外点击预览按钮,并不能直接预览邮件内容然后在邮件主体内容展示出来
根据以上两点基本没法实现 邮件发送后邮件自带 预览功能。

伪方法:
1、在邮件生成时把邮件要预览的部分粘贴成 内容动态图片
2、在邮件生成后读取邮件里面的图片
3、把图片一高清方式设置按比例设置大小,这样图片大小是等比放大,这样不会变窄变长
4、邮件发送是把刚才获取的图片添加到邮件正文当中,从而达到类似预览的效果

步骤如下:
1、把excel 要发送出去的内容区域选中,复制后选中 连接的图片,生成内容是动态的图片在这里插入图片描述2、在邮件生成后读取邮件里面的图片

#region Spire.XLS 获取img
Workbook workbook = new Workbook();
workbook.LoadFromFile(filePath);
//获取工作表
Worksheet sheet = workbook.Worksheets["汇总分析"];
Dictionary<string, string> keyValuesImg = new Dictionary<string, string>();
foreach (Spire.Xls.ExcelPicture picture in sheet.Pictures)
{
	/*Jpg:压缩,Png:无损压缩,Bmp:无压缩*/
	Image image = picture.Picture;
	MemoryStream ms = new MemoryStream();
	image.Save(ms, System.Drawing.Imaging.ImageFormat.Png);
	picture.Picture.Save("C:\\Image" + picture.Name + ".PNG", System.Drawing.Imaging.ImageFormat.Png);
	picture.Picture.Save($@"{AppDomain.CurrentDomain.BaseDirectory}ExcelReport\OEE\OEE报表\Image" + picture.Name + ".PNG", System.Drawing.Imaging.ImageFormat.Png);
	if (!keyValuesImg.ContainsKey(picture.Name.Trim()))
	{
		keyValuesImg.Add(picture.Name.Trim(), Convert.ToBase64String(ms.ToArray()));
	}

	//Image image = picture.Picture;
	//MemoryStream ms = new MemoryStream();
	设置质量
	//EncoderParameters encoderParameters = new EncoderParameters(1);
	//encoderParameters.Param[0] = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 100L);
	//ImageCodecInfo jpgEncoder = GetImageEncoder(ImageFormat.Bmp);
	保存
	//image.Save(ms, jpgEncoder, encoderParameters);
	//baseimg = Convert.ToBase64String(ms.ToArray());
	//picture.Picture.Save("C:\\Image" + picture.Name + ".Bmp", jpgEncoder, encoderParameters);

}
workbook.Dispose();

#endregion

3、设置图片等比大小和质量

/*Jpg:压缩,Png:无损压缩,Bmp:无压缩*/
//设置质量
EncoderParameters encoderParameters = new EncoderParameters(1);
encoderParameters.Param[0] = new EncoderParameter(System.Drawing.Imaging.Encoder.Quality, 100L);
ImageCodecInfo jpgEncoder = GetImageEncoder(ImageFormat.Bmp);

4、把图片添加到邮件正文当中,并发送邮件

#region SendEmail

/*创建 HTML 内容,将图片嵌入其中*/
string htmlBody = "<html><body>";
htmlBody += @"<p style='font-size:14px; font-weight:bold'>Dear All,</p>";
htmlBody += @"<p style='font-size:14px;'>&nbsp;&nbsp;&nbsp;&nbsp以下是当月设备OEE Report,请查阅<a href='https://xxxxxxx.com.hk/Home/Report?type=OEEReport'>【Dashboard】</a>,谢谢!</p>";
htmlBody += @"<p style='font-size:14px;'>&nbsp;&nbsp;&nbsp;&nbsp如需详细了解请查看附件明细数据,或 公共盘查询:<a href='file://filesvr02/Dashboard/OEE'>\\filesvr02\Dashboard\OEE</a></p>";
foreach (var entry in keyValuesImg)
{
	htmlBody += string.Format("<p><img src='data:image/png;base64,{0}' /></p>", entry.Value.ToString());
}
htmlBody += @"</body></html>";

/*文件流发送*/
MemoryStream memoryStream = new MemoryStream(File.ReadAllBytes(filePath));
// Create a StreamAttachment from the memory stream
List<StreamAttachment> attachment = new List<StreamAttachment>()
{
	new StreamAttachment{
		stream = memoryStream,
		name = $@"OEE-Report-{DateTime.Now.AddDays(-1).ToString("M-d")}.xlsx",
		mediaTyp = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
	}
};
EmailHelper.SendToEmail(listemai1, listemai2, "OEE-Report", htmlBody.ToString(), true, attachment, "Dashboard");
memoryStream.Dispose();

#endregion

效果:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2229411.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Boot 3 + Spring Security + Knife4j 无法访问 Swagger 文档的问题及解决方案

背景介绍 在使用Spring Boot 3框架结合Spring Security进行项目开发时&#xff0c;我们可能会遇到集成Knife4j后Swagger文档无法正常访问的情况。本文将探讨可能的原因以及相应的解决办法。 常见问题 问题描述 当配置好Spring Security后尝试通过Knife4j访问API文档页面时&…

构建校园社团信息管理平台:Spring Boot技术的核心要点

6系统测试 6.1概念和意义 测试的定义&#xff1a;程序测试是为了发现错误而执行程序的过程。测试(Testing)的任务与目的可以描述为&#xff1a; 目的&#xff1a;发现程序的错误&#xff1b; 任务&#xff1a;通过在计算机上执行程序&#xff0c;暴露程序中潜在的错误。 另一个…

Spring 框架中常见的注解(Spring、SpringMVC、SpringBoot)

1. Spring 中常见注解 还有Recourse&#xff1a;相当于AutowiredQualifier Value : 用于将配置文件中的值注入到Bean的字段中。 Bean : 用于在配置类中声明一个Bean。 Lazy : 用于延迟加载Bean。 2. SpringMVC 中常见注解 还有GetMapping PostMapping PutMapping DeleteMapp…

深度学习笔记之BERT(一)BERT的基本认识

深度学习笔记之BERT——BERT的基本认识 引言回顾&#xff1a;Transformer的策略回顾&#xff1a;Word2vec的策略和局限性 BERT \text{BERT} BERT的基本理念抽象的双向BERT的预训练策略 预训练与微调 引言 从本节开始&#xff0c;将介绍 BERT \text{BERT} BERT系列模型以及其常…

【华为HCIP实战课程二十八】中间到中间系统协议IS-IS邻居关系排错,网络工程师

一、ISIS邻居关系条件 1、同一层次(比如Level-2路由器不能和Level-1路由器形成邻居关系) 2、同一区域(L1必须同一区域) 3、同一网段 R1和R2之间分别配置如下IP地址和掩码: R1 的接口S1/0/0掩码为/24 R2的接口S1/0/0配置成掩码/28: 此时R1和R2依然可以建立ISIS邻居关系…

微信小程序,打开新的项目,调试遇见[ app.json 文件内容错误] app.json: 在项目根目录未找到 app.json

1&#xff0c;首先&#xff0c;在开发工具右上角&#xff0c;打开详情&#xff1b;设置基础库&#xff1b;3.6.3 2&#xff0c;第二步&#xff0c;在项目目录下&#xff0c;找到app.json文件存在 3&#xff0c;第三步&#xff0c;修改项目根目录下&#xff0c;project.config.j…

使用RabbitMQ实现微服务间的异步消息传递

使用RabbitMQ实现微服务间的异步消息传递 RabbitMQ简介 安装RabbitMQ 在Ubuntu上安装RabbitMQ 在CentOS上安装RabbitMQ 配置RabbitMQ 创建微服务 生产者服务 安装依赖 生产者代码 消费者服务 消费者代码 运行微服务 消息模式 直接模式 生产者代码 消费者代码 扇出模式 生产…

数字教学的创新引擎:构建数字教学知识库

在教育行业&#xff0c;数字化转型正成为推动教育现代化的重要力量。数字教学知识库作为这一转型的核心组成部分&#xff0c;对于整合教育资源、提升教学质量、促进教育公平具有重要意义。本文将探讨数字教学知识库的构建策略、应用价值&#xff0c;并分析其在教育行业的深远影…

【ArcGISPro】制作简单的ArcGISPro-AI助手

【python】AI Navigator的使用及搭建本机大模型_anaconda ai navigator-CSDN博客 【Python】AI Navigator对话流式输出_ai大模型流式输出效果(打字效果) python-CSDN博客 【C#】调用本机AI大模型流式返回_怎么实现调用本地大模型时实现流式输出-CSDN博客 【ArcGISPro】宣布推…

web文件包含include

php伪协议 在 PHP 中&#xff0c;伪协议&#xff08;Pseudo Protocols&#xff09; 也被称为 流包装器&#xff0c;这些伪协议以 php:// 开头&#xff0c;后面跟着一些参数&#xff0c;用于指定 要执行的操作 或 需要访问的资源。 伪协议表明这些协议并不是一个 真实的外部协议…

【力扣打卡系列】验证二叉搜索树

坚持按题型打卡&刷&梳理力扣算法题系列&#xff0c;语言为go&#xff0c;Day17 验证二叉搜索树 题目描述 解题思路 前序遍历&#xff1a;先访问节点值&#xff0c;再访问左右子树有效二叉搜索树的定义 节点的左子树只包含小于当前节点的数节点的右子树只包含大于当前节…

【天线&空中农业】蜜蜂检测系统源码&数据集全套:改进yolo11-ASF

改进yolo11-dysample等200全套创新点大全&#xff1a;蜜蜂检测系统源码&#xff06;数据集全套 1.图片效果展示 项目来源 人工智能促进会 2024.10.30 注意&#xff1a;由于项目一直在更新迭代&#xff0c;上面“1.图片效果展示”和“2.视频效果展示”展示的系统图片或者视频可…

hive将包含逗号的字段拆分为多列

目录 一、概述 二、行动 1.准备数据 2.数据清洗 3.substring_index函数 4.split函数实现 一、概述 想将hive表中包含逗号的字段按逗号做分隔符进行分列操作 二、行动 1.准备数据 --1 select {1,2,3,4,5,6,7,8} as num_str --使用的数据2.数据清洗 --2 select num_s…

基于MPC控制器的混合动力EMS能量管理系统simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 4.1 MPC 控制器原理 4.2 能量管理模块 4.3 动力模型 5.完整工程文件 1.课题概述 整个系统可以划分为如下几个模块。 其中&#xff0c;能量管理模块其包括&#xff1a;MPC控制器模块&#xff0c;驱动扭…

11-Python基础编程之错误和异常

Python基础编程之错误和异常 概念错误异常 常见的系统异常异常的解决预防捕捉处理异常with语句 手动抛出异常自定义异常 概念 错误 可以通过代码进行修复&#xff1b; 异常 需要提前考虑&#xff0c;设定限制条件&#xff1b;不能通过代码进行修复&#xff1b; 常见的系…

使用 Elastic、OpenLLMetry 和 OpenTelemetry 跟踪 LangChain 应用程序

作者&#xff1a;来自 Elastic Bahubali Shetti Langchain 应用程序的使用正在增长。构建基于 RAG 的应用程序、简单的 AI 助手等的能力正在成为常态。观察这些应用程序更加困难。考虑到现有的各种选项&#xff0c;本博客展示了如何将 OpenTelemetry 检测与 OpenLLMetry 结合使…

b站小土堆PyTorch视频学习笔记(二)

Dataloader:提供不同类型的数据集&#xff1b;为后面的网络提供不同的数据形式 Dataset&#xff1a;提供一种方式去获取数据及其label&#xff08;标签&#xff09; 主要实现以下两个功能&#xff1a; {如何获取每一个数据及其lable&#xff1b;告诉我们总共有多少数据} fr…

操作系统实验记录

实验零:虚拟机安装 一、安装vmware虚拟机 与vmware匹配搜索结果 - 考拉软件 (rjctx.com),下载17.5.1版本即可下载后对照教程安装 二、下载iso虚拟驱动 搜索清华大学镜像网站,点击再搜ubuntu,下载这个4.1GB的iso文件安装后打开vmware虚拟机 三、配置vmware虚拟机 右键管…

【YOLO 系列】基于YOLO的行人口罩检测系统【python源码+Pyqt5界面+数据集+训练代码】

前言 在当前全球公共卫生形势下&#xff0c;戴口罩已成为预防呼吸道疾病传播的重要措施。然而&#xff0c;确保每个人都遵守这一规定仍然是一项挑战。为了提高公共场合的口罩佩戴合规性&#xff0c;我们开发了基于YOLO V8的行人口罩检测系统。该系统利用深度学习技术&#xff…

SpringBoot节奏:Web音乐网站构建手册

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统&#xff0c;它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等&#xff0c;非常…