邮件发送excel带预览excel功能

在这里插入图片描述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.xdnf.cn/news/934.html

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

相关文章

HCIA(DHCP服务)

第三节 开启DHCP服务 创建地址池 调用全局服务 [R1]dhcp enable 开启DHCP服务 [R1]ip pool AA 创建地址池 [R1-ip-pool-AA]network 192.168.1.0 mask 24 写入网段 [R1-ip-pool-AA]gateway-list 192.168.1.1 写入网关 [R1-ip-pool-AA]dns-list 8.8.8.8 114.1…

java项目之文理医院预约挂号系统源码(springboot)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的文理医院预约挂号系统。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息。 项目简介&#xff1a; 本系统的使用角色可…

A4-C四驱高防变电站巡检机器人

在电力行业数字化、智能化转型进程中&#xff0c;搭载多模态成像传感器的变电站巡检机器人、视频监控设备逐渐取代传统人工&#xff0c;成为变电设备状态监测的主要工具。变电站巡检机器人具有全天候、非接触式、多参量测量等特点&#xff0c;结合内置人工智能算法完成仪表识别…

【华为HCIP实战课程三十】中间到中间系统协议IS-IS路由渗透及TAG标识详解,网络工程师

一、路由泄露 1、默认情况Level 1不会学到Level2的明细路由&#xff0c;L2可以学到L1的明细路由 2、FIB数据转发&#xff0c;路由负载&#xff0c;通过随机数据中的五元组hash,hash值决定数据走哪条链路 R1设备ping和telnet通过抓包查看走的都是S1/0/0接口 抓包进行过滤;ip.a…

面向对象三大特征之一:封 装

1、特点 封装是面向对象的核心思想&#xff0c;两层含义&#xff1a;一是一个整体&#xff08;把对象的属性和行为看成一个整体&#xff0c;即封装在一个对象种&#xff09;&#xff0c;二是信息隐藏&#xff0c;对外隐藏&#xff0c;但可以通过某种方式进行调用。 2、访问权…

引领汽车行业未来,3D数字化技术如何改变汽车行业?

新能源汽车行业加速发展&#xff0c;新车型密集发布&#xff0c;汽车保有量和车龄的增加&#xff0c;也同时点燃了汽车后市场的增长引擎。对于车企而言&#xff0c;如何全方面优化汽车从研发、生产、售后到营销的各个环节&#xff0c;以便适应快速变化的市场需求&#xff1f; 1…

使用MongoDB Atlas构建无服务器数据库

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 使用MongoDB Atlas构建无服务器数据库 MongoDB Atlas 简介 注册账户 创建集群 配置网络 设置数据库用户 连接数据库 设计文档模式…

萌熊数据科技:剑指脑机转入,开启科技新篇章

近日&#xff0c;科技圈传来一则令人瞩目的消息&#xff0c;天津萌熊数据科技有限公司和天津一万年科技发展有限公司在全国范围内大力开展AI加生命科学的主体业务&#xff0c;并明确将朝着脑机转入方向深入发展&#xff0c;引发了行业内外的广泛关注。 天津萌熊数据科技有限公司…

【云备份项目】json以及jsoncpp库的使用

目录 1.JSON 2.什么是 JSON&#xff1f; 3.JSON 发展史 4.为什么要使用 JSON&#xff1f; 5.JSON 的不足 6.JSON 应该如何存储&#xff1f; 7.什么时候会使用 JSON 7.1.定义接口 7.2.序列化 7.3.生成 Token 7.4.配置文件 8.JSON的语法规则 8.1.对象和数组 8.2.JS…

动态规划-两个数组的dp问题——1035.不相交的线

1.题目解析 题目来源&#xff1a;1035.不相交的线 测试用例 2.算法原理 本题实质上就是寻找两个数组的最长公共子序列&#xff0c;所以可以直接移步到 最长公共子序列 的解析博客&#xff0c;那里更加详细的介绍了如何处理最长公共子序列的判断 1.状态表示 由题目可知是两个…

Android13开发恢复出厂设置默认打开WiFi

案例&#xff1a; 测试要求系统恢复出场设置的时候&#xff0c;默认WiFi打开 代码 找到def_wifi_on,将它修改为true即可 修改路径&#xff1a;QSSI.13/packages/services/Car/car_product/overlay/frameworks/base/packages/SettingsProvider/res/values/defaults.xml

Spring Boot框架下校园社团信息管理的优化策略

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及&#xff0c;互联网成为人们查找信息的重要场所&#xff0c;二十一世纪是信息的时代&#xff0c;所以信息的管理显得特别重要。因此&#xff0c;使用计算机来管理校园社团信息管理系统的相关信息成为必然。…

MySql基础:数据类型

目录 1. 数据类型的整体分类 2. 整数数据类型 2.1 TINYINT 类型 2.2 bit 类型 2.3 小数类型 2.3.1 float 2.3.2 decimal 2.4 字符串类型 2.4.1 char 2.4.3 varchar 2. 5 日期和时间类型 2.6 enum和set类型 补充&#xff1a; 1. 数据类型的整体分类 说明&#xff1a;在…

【测试工具】通过Jmeter压测存储过程

目录 一、存储过程准备1.1、 建立空表1.2、 建立存储过程1.3、调试 二、测试工具准备三、工具配置及执行3.1、配置JDBC Connection Configuration&#xff1a;3.2、配置吞吐量控制器3.3、配置JDBC Request 一、存储过程准备 1.1、 建立空表 CREATE TABLE test_data ( id NUMB…

探讨Facebook的AI研究:未来社交平台的技术前瞻

在数字时代&#xff0c;社交媒体已成为人们日常生活的重要组成部分。作为全球最大的社交网络之一&#xff0c;Facebook不断致力于人工智能&#xff08;AI&#xff09;的研究与应用&#xff0c;以提升用户体验、增强平台功能并推动技术创新。本文将探讨Facebook在AI领域的研究方…

二百七十五、Kettle——ClickHouse增量导入数据补全以及数据修复记录表数据(实时)

一、目的 在完成数据修复后&#xff0c;需要生成修复记录 二、Hive中原有代码 2.1 表结构 --52、数据补全以及数据修复记录表 dwd_data_correction_record create table if not exists hurys_db.dwd_data_correction_record(data_type int comment 数据类型…

无人机之集群控制方法篇

无人机的集群控制方法涉及多个技术和策略&#xff0c;以确保多架无人机能够协同、高效地执行任务。以下是一些主要的无人机集群控制方法&#xff1a; 一、编队控制方法 领航-跟随法&#xff08;Leader-Follower&#xff09; 通过设定一架无人机作为领航者&#xff08;长机&am…

第02章 MySQL环境搭建

一、MySQL的卸载 如果安装mysql时出现问题&#xff0c;则需要将mysql卸载干净再重新安装。如果卸载不干净&#xff0c;仍然会报错安装不成功。 步骤1&#xff1a;停止MySQL服务 在卸载之前&#xff0c;先停止MySQL8.0的服务。按键盘上的“Ctrl Alt Delete”组合键&#xff0…

使用Django REST framework构建RESTful API

使用Django REST framework构建RESTful API Django REST framework简介 安装Django REST framework 创建Django项目 创建Django应用 配置Django项目 创建模型 迁移数据库 创建序列化器 创建视图 配置URL 配置全局URL 配置认证和权限 测试API 使用Postman测试API 分页 过滤和排序…

远程控制项目第二天

所有有关网络编程的项目&#xff0c;最基础的框架就是那些固定的流程&#xff0c;Socket&#xff0c;bind&#xff0c;listen&#xff0c;accept&#xff0c;然后我需要的就是在此基础上进行完善和优化&#xff0c;然后再Windows网络编程中&#xff0c;在socket前首先需要初始化…