代码已托管GitHub,仓库地址:XietongAuto,包含了NPOI的下载。


C# System.Net.Mail命名空间

官网API地址为:https://docs.microsoft.com/zh-cn/dotnet/api/system.net.mail?redirectedfrom=MSDN&view=netframework-4.8

通过该命名空间,可实现基于POP协议的邮箱自动发送功能,具体的C# DLL后面提供。

        //mailContent是发送邮件的内容,mailSubject是发送邮件的标题,mailTo发送给哪个邮箱
        public static int SendEmail(string mailContent, string mailSubject, string mailTo)
        {
            // 设置例网易的smtp
            string smtpServer = "smtp.qq.com";// "14.18.245.164"; //SMTP服务器
            string mailFrom = "XXXX@qq.com"; //登陆用户名
            string userPassword = "XXXXXXXXX";//登陆密码

            // 邮件服务设置
            SmtpClient smtpClient = new SmtpClient();
            smtpClient.EnableSsl = true;
            smtpClient.UseDefaultCredentials = false;
            smtpClient.DeliveryMethod = SmtpDeliveryMethod.Network;//指定电子邮件发送方式
            smtpClient.Host = smtpServer; //指定SMTP服务器
            smtpClient.Timeout = 5000;
            smtpClient.Port = 587; //不设置默认为25端口
            smtpClient.Credentials = new System.Net.NetworkCredential(mailFrom, userPassword);//用户名和密码
           
            MailMessage mailMessage = new MailMessage(mailFrom, mailTo); // 发送人和收件人
            mailMessage.Subject = mailSubject;//主题
            mailMessage.Body = mailContent;//内容
            mailMessage.BodyEncoding = Encoding.UTF8;//正文编码
            mailMessage.IsBodyHtml = true;//设置为HTML格式
            mailMessage.Priority = MailPriority.Low;//优先级

            try
            {
                ServicePointManager.ServerCertificateValidationCallback =
                           delegate (Object obj, X509Certificate certificate, X509Chain chain, SslPolicyErrors errors) { return true; };
                smtpClient.Send(mailMessage); // 发送邮件
                return 1;
            }
            catch (SmtpException ex)
            {
                Logger.Create("- 邮件发送异常", ex.ToString());
                return 0;
            }
        }

NPOI of C#

  • 介绍
    NPOI是指构建在POI 3.x版本之上的一个程序,NPOI可以在没有安装Office的情况下对Word或Excel文档进行读写操作。其中有Java,C#的实现,具体的C# DLL后面提供。
  • excel读操作
        private int read_excel()
        {
            //文件的绝对路径
            string excelpath = textBox_path.Text;
            IWorkbook wk = null;
            if (File.Exists(excelpath))
            {
                //获取文件后缀,根据后缀.xls或者.xlsx选择不同的IWorkbook
                string extension = System.IO.Path.GetExtension(excelpath);
                FileStream fs = File.OpenRead(excelpath);
                if (extension.Equals(".xls"))
                {
                    //读取xls文件中的数据
                    wk = new HSSFWorkbook(fs);
                }
                else
                {
                    //读取xls文件中的数据
                    wk = new XSSFWorkbook(fs);
                }

                fs.Close();

                ISheet sheet = wk.GetSheetAt(0);
                string sheetname = wk.GetSheetName(0); //根据序号获取sheet的名称
                int rowcount = sheet.LastRowNum;  //获取该sheet的总行数

                for (int j = 2; j <= rowcount; j++)
                {
                    IRow row = sheet.GetRow(j);  //读取当前行数据
                     MessageBox.Show(row.GetCell(2)); //获取该行的第三列的数据
                }
                return count;
            }
            else
            {
                return 0;
            }
        }
  • excel写操作 (基于已有的文件进行写操作,避免设置样式)
        public static void WriteExcel(string path)
        {
            string cell_val1 = "cell_val1";
            string cell_val2 = "cell_val2";

            if (File.Exists(path))
            {
                IWorkbook wk = null;
                string extension = System.IO.Path.GetExtension(path);

                FileStream fs = File.Open(path, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);

                if (extension.Equals(".xls"))
                {
                    //把xls文件中的数据写入wk中
                    wk = new HSSFWorkbook(fs);
                }
                else
                {
                    //把xlsx文件中的数据写入wk中
                    wk = new XSSFWorkbook(fs);
                }
                fs.Close();
                //读取当前表数据
                ISheet sheet = wk.GetSheetAt(0);

                IRow row = sheet.GetRow(1);
                row.Height = 20 * 20;

                ICell c1 = row.CreateCell(1);
                ICell c2 = row.CreateCell(3);
                c1.SetCellValue(cell_val1);
                c2.SetCellValue(cell_val2);

                fs.Close();
                using (FileStream fss = File.Open(@"E:\test.xlsx", FileMode.OpenOrCreate, FileAccess.ReadWrite))
                {
                    wk.Write(fss);
                    fss.Close();
                }
            }
        }
  • excel写操作 ( 全新写入一个excel文件)
//新建Excel文件   
IWorkbook workbook = new HSSFWorkbook();

//新建Sheet表
ISheet sheet = workbook.CreateSheet("Test Result");

//创建单元格样式和字体样式
IFont font = workbook.CreateFont();
ICellStyle style = workbook.CreateCellStyle(); 
   
//设置居中       
style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CenterSelection;

//设置内容垂直居中
style.VerticalAlignment = VerticalAlignment.Justify;

//字体加粗     
font.Boldweight = short.MaxValue;

//设置字体大小
font.FontHeightInPoints = 12;

style.SetFont(font);
IFont font1 = workbook.CreateFont(); 
ICellStyle style1 = workbook.CreateCellStyle();
style1.Alignment = NPOI.SS.UserModel.HorizontalAlignment.CenterSelection; 
style1.VerticalAlignment = VerticalAlignment.Justify;

//修改列宽
sheet.SetColumnWidth(1, 18 * 400);
sheet.SetColumnWidth(2, 18 * 256);     
string[] value1 = { "NO", "UUT SN", "Condition"};
//新建行
IRow row = sheet.CreateRow(0);
        
for (int a = 0; a < value1.Length; a++)
{
  //将数组中的值逐一添加到单元格中
  row.CreateCell(a).SetCellValue(Convert.ToString(value1[a]));

 //给每个单元格写入样式

  row.GetCell(a).CellStyle = style;
 }
for (int i = 0; i < 32; i++)
{
  //追加行
   IRow row1 = sheet.CreateRow((sheet.LastRowNum + 1));
   row1.CreateCell(0).SetCellValue(i + 1);
   row1.CreateCell(1).SetCellValue("5473567I008D9193541A1000041");
   row1.CreateCell(2).SetCellValue("Temperature ");
   row1.GetCell(0).CellStyle = style1;
   row1.GetCell(1).CellStyle = style1;
   row1.GetCell(2).CellStyle = style1;
   font1.Boldweight = short.MaxValue;
   style1.SetFont(font1);

  //新建path ,文件处理模式为新增:FileMode.Create,
   FileStream fs = new FileStream(@"C:\Users\lenovo\Desktop\Test Result.xls", FileMode.Create, FileAccess.Write);
  //写入
   workbook.Write(fs);
 //关闭
   fs.Close();
 }
  • excel根据写入的数据类型进行判断的工具类
        /// <summary>
        /// 设置单元格数据类型
        /// </summary>
        /// <param name="cell">目标单元格</param>
        /// <param name="obj">数据值</param>
        /// <returns></returns>
        public static void SetCellValue(ICell cell, object obj)
        {
            if (obj.GetType() == typeof(int))
            {
                cell.SetCellValue((int)obj);
            }
            else if (obj.GetType() == typeof(double))
            {
                cell.SetCellValue((double)obj);
            }
            else if (obj.GetType() == typeof(IRichTextString))
            {
                cell.SetCellValue((IRichTextString)obj);
            }
            else if (obj.GetType() == typeof(string))
            {
                cell.SetCellValue(obj.ToString());
            }
            else if (obj.GetType() == typeof(DateTime))
            {
                cell.SetCellValue((DateTime)obj);
            }
            else if (obj.GetType() == typeof(bool))
            {
                cell.SetCellValue((bool)obj);
            }
            else
            {
                cell.SetCellValue(obj.ToString());
            }
        }

XietongAuto应用

代码仓库地址为:https://github.com/luozhengszj/XietongAuto
使用该应用,可以自动批量发送自定义的邮件(适用与任何的POP协议邮箱),主要具备特点:

  • 该仓库代码可以根据选择的excel文件路径,进行读取excel;
  • 邮件的标题的统一设置;
  • 邮件的内容,可以根据luozhengQAQ+数字,及读取的excel文件的第三行往后、第四列往后的内容进行替换;
  • 当发送邮件的目标邮件错误时,会有日志记录;
  • 该仓库包含了c# npoi的dll文件,直接下载该代码仓库即可看到npoi的文件。

个人博客:Loak 正 - 关注人工智能及互联网的个人博客
文章地址:使用c#的System.Net.Mail包、NPOI包实现了基于excel表格的邮箱自定义批量发送