1.利用NPOI生成EXCEL

2.导出excel之后发送邮件

//导出excel

//path :保存路径

//dt:要导出的数据 

public static bool DataTableToExcel(String path, DataTable dt)
{
  bool result = false;
  IWorkbook workbook = null;
  FileStream fs = null;
  IRow row = null;
  ISheet sheet = null;
  ICell cell = null;
  try
  {
    if (dt != null && dt.Rows.Count > 0)
    {
      workbook = new HSSFWorkbook();
      sheet = workbook.CreateSheet("停台信息");//创建一个名称为Sheet0的表
      int rowCount = dt.Rows.Count;//行数
      int columnCount = dt.Columns.Count;//列数

      //设置列头
      row = sheet.CreateRow(0);//excel第一行设为列头
      for (int c = 0; c < columnCount; c++)
      {
        cell = row.CreateCell(c);
        cell.SetCellValue(dt.Columns[c].ColumnName);
      }

      //设置每行每列的单元格,
      for (int i = 0; i < rowCount; i++)
      {
        row = sheet.CreateRow(i + 1);
        for (int j = 0; j < columnCount; j++)
        {
          cell = row.CreateCell(j);//excel第二行开始写入数据
          cell.SetCellValue(dt.Rows[i][j].ToString());
        }
      }
      using (fs = File.OpenWrite(path))
      {
        workbook.Write(fs);//向打开的这个xls文件中写入数据
        result = true;
      }
    }
  return result;

  }
  catch (Exception ex)
  {
    if (fs != null)
    {
      fs.Close();
    }
    return false;
  }
}

//发送邮件功能

/// <summary>
/// C#发送邮件函数
/// </summary>
/// <param name="from">发送者邮箱</param>
/// <param name="fromer">发送人</param>
/// <param name="to">接受者邮箱</param>
/// <param name="toer">收件人</param>
/// <param name="Subject">主题</param>
/// <param name="Body">内容</param>
/// <param name="file">附件</param>
/// <param name="SMTPHost">smtp服务器</param>
/// <param name="SMTPuser">邮箱</param>
/// <param name="SMTPpass">密码</param>

/// <returns></returns>
public bool sendmail(string sfrom, string sfromer, string sto, string stoer, string sSubject, string sBody, string sfile, string sSMTPHost, string sSMTPuser, string sSMTPpass)
{
////设置from和to地址
MailAddress from = new MailAddress(sfrom, sfromer);
MailAddress to = new MailAddress(sto, stoer);

////创建一个MailMessage对象
MailMessage oMail = new MailMessage(from, to);

//// 添加附件
if (sfile != "")
{
oMail.Attachments.Add(new Attachment(sfile));
}

////邮件标题
oMail.Subject = sSubject;

////邮件内容
oMail.Body = sBody;

////邮件格式
oMail.IsBodyHtml = false;

////邮件采用的编码
oMail.BodyEncoding = System.Text.Encoding.GetEncoding("GB2312");

////设置邮件的优先级为高
oMail.Priority = MailPriority.High;

////发送邮件
SmtpClient client = new SmtpClient();
////client.UseDefaultCredentials = false;
client.Host = sSMTPHost;
client.Credentials = new NetworkCredential(sSMTPuser, sSMTPpass);
client.DeliveryMethod = SmtpDeliveryMethod.Network;
try
{
client.Send(oMail);
return true;
}
catch (Exception err)
{
return false;
}
finally
{
////释放资源
oMail.Dispose();
}

}

//发送邮件

public String SendEmail( )
{
String vResult = "";
//校验值
bool vFlag = true;
//Sql语句
String vSql = @"
Sql语句
";

String vDate = DateTime.Now.AddDays(-1).ToString("yyyy-MM-dd");
String vPath = "D:\\ExpExcel\\";
vPath += "停台信息 " + vDate + ".xls";
try
{

DataTable dt = new DataTable();
dt = GetExpData(vSql);

vFlag = DataTableToExcel(vPath, dt);
}
catch (Exception ex)
{
vFlag = false;
vResult = "执行失败!" + ex;
}

if (vFlag)
{

String vMDate = DateTime.Now.AddDays(-1).ToString("MM月dd日");

string from = "发送人邮箱";
string fromer = "A.Link";
string to = "接收人邮箱";
string toer = "陈工";
string Subject = "停台信息 " + vDate;\\标题
string file = vPath;\\附件所在路径
string Body = @"邮件内容";
string SMTPHost = "邮箱服务器地址";
string SMTPuser = "发送人账号";
string SMTPpass = "密码";
SendEmail se = new SendEmail();

se.sendmail(from, fromer, to, toer, Subject, Body, file, SMTPHost, SMTPuser, SMTPpass);
vResult = "执行成功!";
}
return vResult;

}

如果需要源码就给我留言,但是我不经常上,不会写博客

WebService--导出excel并将excel发送到邮箱的更多相关文章

  1. C#/Net定时导出Excel并定时发送到邮箱

    一.定时导出Excel并定时发送到邮箱   首先我们先分析一下该功能有多少个小的任务点:1.Windows计划服务 2.定时导出Excel定指定路径 3.定时发送邮件包含附件   接下来我们一个个解决 ...

  2. 如何使用NPOI 导出到excel和导入excel到数据库

    近期一直在做如何将数据库的数据导出到excel和导入excel到数据库. 首先进入官网进行下载NPOI插件(http://npoi.codeplex.com/). 我用的NPOI1.2.5稳定版. 使 ...

  3. c# 高效率导出多维表头excel

    [DllImport("User32.dll", CharSet = CharSet.Auto)] public static extern int GetWindowThread ...

  4. C#导出Excel,并且设置Excel单元格格式,合并单元格.

    注:要添加COM组件 Microsoft Excel 11.0 Object Library  引用. 具体代码如下: using System; using System.Collections.G ...

  5. thinkphp用phpexcel读取excel,并修改列中的值,再导出excel,带往excel里写入图片

    <?php class GetpriceAction extends AdministratorAction { // 文件保存路径 protected $savepath; // 允许上传的文 ...

  6. 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法

    -----转载:http://blog.csdn.net/sgear/article/details/7663502 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格 ...

  7. PHP导出MySQL数据到Excel文件

    PHP导出MySQL数据到Excel文件 转载 常会碰到需要从数据库中导出数据到Excel文件,用一些开源的类库,比如PHPExcel,确实比较容易实现,但对大量数据的支持很不好,很容易到达PHP内存 ...

  8. ASP.NET导出EXCEl方法使用COM.EXCEL不使用EXCEl对象

    第一种:导出gridVIEW中的数据,用hansTABLE做离线表,将数据库中指定表中的所有数据按GRIDVIEW中绑定的ID导出 只能导出数据不能去操作相应的EXCEl表格,不能对EXCEL中的数据 ...

  9. 在ASP.NET中将GridView数据导出到Word、Excel

    在ASP.NET中将GridView数据导出到Word.Excel asp.net,导出gridview数据到Word,Excel,PDF   #region Export to Word, Exce ...

随机推荐

  1. Struts2 OGNL表达式、ValueStack

    OGNL简介 OGNL,即Object-Graph Navigation Language,对象视图导航语言,是一种数据访问语言,比EL表达式更加强大: EL只能从11个内置对象中取值,且只能获取属性 ...

  2. foreachRDD

    需求: 将统计结果写入到MySQL create table wordcount( word varchar(50) default null, wordcount int(10) default n ...

  3. visudo: /etc/sudoers is busy, try again later

    启动visudo时,报错"visudo: /etc/sudoers is busy, try again later" 解决思路:杀掉visudo进程 ps -ef|grep vi ...

  4. linux 本地套接字通信

    本地套接字通信 利用本地套接字,也可以进程间通信. 本地套接字和有名管道一样都利用伪文件 管道的文件类型是p 本地套接字的文件类型是s. 当调用bind函数后,就会生成本地套接字对应的伪装文件 srw ...

  5. 【转载】CMake 两种变量原理

    原文地址:https://cslam.cn/archives/c9f565b5.html 摘要: 本文记录一下 CMake 变量的定义.原理及其使用.CMake 变量包含 Normal Variabl ...

  6. Python语言基础06-字符串和常用数据结构

    本文收录在Python从入门到精通系列文章系列 1. 使用字符串 第二次世界大战促使了现代电子计算机的诞生,最初计算机被应用于导弹弹道的计算,而在计算机诞生后的很多年时间里,计算机处理的信息基本上都是 ...

  7. LSTM——长短时记忆网络

    LSTM(Long Short-term Memory),长短时记忆网络是1997年Hochreiter和Schmidhuber为了解决预测位置与相关信息之间的间隔增大或者复杂语言场景中,有用信息间隔 ...

  8. Ubuntu下搭建Kubernetes集群(4)--部署K8S Dashboard

    K8S Dashboard是官方的一个基于WEB的用户界面,专门用来管理K8S集群,并可展示集群的状态.K8S集群安装好后默认没有包含Dashboard,我们需要额外创建它. 首先我们执行命令: wg ...

  9. 201871010132-张潇潇-《面向对象程序设计(java)》第六-七周学习总结

    201871010132-张潇潇-<面向对象程序设计(java)>第六-七周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh ...

  10. 201871010111-刘佳华《面向对象程序设计(java)》第二周学习总结

    201871010111-刘佳华<面向对象程序设计(java)>第二周学习总结 项目 内容 这个作业属于哪个课程 <https://www.cnblogs.com/nwnu-daiz ...