using System.Data;
 using System.Data.OleDb;
 /// <summary>
 /// Excel转为DataTable
 /// </summary>
 /// <param name="ExcelName"></param>
 /// <returns></returns>
 public static DataTable ExcelToDataTable(string filePath)
 {
     string strCon = "Provider = Microsoft.ACE.OLEDB.12.0 ;Data Source=" + filePath + ";Extended Properties='Excel 12.0;HDR=YES;'";// IMEX=1为导入模式
     OleDbConnection olecon = new OleDbConnection(strCon);
     olecon.Open();
     DataTable dt = olecon.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new Object[] { null, null, null, "TABLE" });
     ]["TABLE_NAME"].ToString();//获取Excel表名
     OleDbDataAdapter myda = new OleDbDataAdapter("SELECT * FROM [" + sheetName + "]", strCon);
     DataTable mydt = new DataTable();
     myda.Fill(mydt);
     olecon.Close();
     return mydt;
 }
 /// <summary>
 /// DataTable导出Excel
 /// GridView作为中间数据格式转换用途
 /// </summary>
 /// <param name="page">Page对象</param>
 /// <param name="columns">导出数据源</param>
 /// <param name="dt">导出显示列与对应数据列,Key:Excel列名,Value:数据源列名</param>
 /// <param name="fileName">导出文件名,无需带后缀</param>
 public static void GridViewToExcel(Page page, DataTable dt, Dictionary<string, string> columns, string fileName)
 {
      || columns == )
     {
         return;
     }

     if (string.IsNullOrEmpty(fileName.Trim()))
     {
         fileName = "DataToExcel";
     }

     DataTable temp = new DataTable();

     foreach (KeyValuePair<string, string> item in columns)
     {
         temp.Columns.Add(item.Key);
     }

     foreach (DataRow dr in dt.Rows)
     {
         DataRow drs = temp.NewRow();

         foreach (KeyValuePair<string, string> item in columns)
         {
             drs[item.Key] = dr[item.Value];
         }
         temp.Rows.Add(drs);
     }

     GridView gv = new GridView();
     gv.DataSource = temp;
     gv.AllowPaging = false;
     gv.EnableViewState = false;
     gv.DataBind();

     StringWriter strWriter = new StringWriter();
     HtmlTextWriter htmlWriter = new HtmlTextWriter(strWriter);

     page.Response.Clear();
     page.Response.Buffer = true;
     page.Response.Charset = "GB2312";
     page.Response.HeaderEncoding = System.Text.Encoding.GetEncoding("GB2312");
     page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
     page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName + ".xls");
     page.Response.ContentType = "application/ms-excel";
     gv.RenderControl(htmlWriter);
     page.Response.Write(strWriter.ToString());
     page.Response.End();
 }
 /// <summary>
 /// DataTable导出Excel,自定义Html Table格式
 /// </summary>
 /// <param name="page">Page对象</param>
 /// <param name="dt">DataTable</param>
 /// <param name="columns">导出显示列与对应数据列,Key:Excel导出列名,Value:数据源列名</param>
 /// <param name="fileName">导出文件名,无需带后缀</param>
 public static void ToExcel(Page page, DataTable dt1, Dictionary<string, string> columns, string fileName)
 {

      || columns == )
     {
         return;
     }

     if (string.IsNullOrEmpty(fileName.Trim()))
     {
         fileName = "DataToExcel";
     }
     page.Response.Clear();
     page.Response.Buffer = true;
     page.Response.Charset = "GB2312";
     page.Response.HeaderEncoding = System.Text.Encoding.GetEncoding("GB2312");
     page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
     page.Response.ContentType = "application/ms-excel";
     page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName + ".xls");

     System.Text.StringBuilder builder = new System.Text.StringBuilder();
     builder.Append("<html xmlns:x=\"urn><head>\n");
     builder.Append("<meta http-equiv=\"Content-Language\" content=\"zh-cn\"><meta http-equiv=\"Content-Type\" content=\"text/html;charset=gb2312\"></head>");
     builder.Append("<table border=1 style=\"vnd.ms-excel.numberformat:@\"><tr>");

     foreach (KeyValuePair<string, string> item in columns)
     {
         builder.Append("<th>" + item.Key + "</th>");
     }

     builder.Append("</tr>");

     foreach (DataRow item in dt1.Rows)
     {
         builder.Append("<tr>");
         foreach (KeyValuePair<string, string> kv in columns)
         {
             if (IsDateTime(item[kv.Value].ToString()))
                 builder.Append("<td style=\"vnd.ms-excel.numberformat:yyyy-MM-dd\">" + item[kv.Value] + "</td>");
             else
                 builder.Append("<td>" + item[kv.Value] + "</td>");
         }
         builder.Append("</tr>");
     }
     builder.Append("</table>");
     page.Response.Write(builder.ToString());
     page.Response.Flush();
     page.Response.End();
 }

C#中 导入和导出Excel的方法的更多相关文章

  1. Java中导入、导出Excel

    原文:Java中导入.导出Excel 一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已 ...

  2. 我是陌生人 Java中导入、导出Excel

    我是陌生人 Java中导入.导出Excel 一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是: ...

  3. [转]Java中导入、导出Excel

    原文地址:http://blog.csdn.net/jerehedu/article/details/45195359 一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样 ...

  4. 在mvc4中上传、导入和导出excel表方法总结

    通过excel的导入导出练习,使用NPOI组件还是方便一点,所有下面就以NPOI下的导入导出给出实例,通过网页导入excel表,首先上传,再导入数据到库,这里为了方便就不导入到库中了,直接拿到数据.导 ...

  5. asp.net中导出Excel的方法

    一.asp.net中导出Excel的方法: 本文转载 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出 ...

  6. Java中使用poi导入、导出Excel

    一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际 ...

  7. 前端必读3.0:如何在 Angular 中使用SpreadJS实现导入和导出 Excel 文件

    在之前的文章中,我们为大家分别详细介绍了在JavaScript.React中使用SpreadJS导入和导出Excel文件的方法,作为带给广大前端开发者的"三部曲",本文我们将为大家 ...

  8. html table表格导出excel的方法 html5 table导出Excel HTML用JS导出Excel的五种方法 html中table导出Excel 前端开发 将table内容导出到excel HTML table导出到Excel中的解决办法 js实现table导出Excel,保留table样式

    先上代码   <script type="text/javascript" language="javascript">   var idTmr; ...

  9. 分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility (续3篇-导出时动态生成多Sheet EXCEL)

    ExcelUtility 类库经过我(梦在旅途)近期不断的优化与新增功能,现已基本趋向稳定,功能上也基本可以满足绝大部份的EXCEL导出需求,该类库已在我们公司大型ERP系统全面使用,效果不错,今天应 ...

随机推荐

  1. Nagios 安装配置

    ##Debian 6 安装server # apt-get install nagios* 一路设置好各种密码,成功后访问 http://ip/nagios3 既可,默认用户*nagiosadmin* ...

  2. GitLab 的 Developer 角色没有权限提交问题

    "C:\Program Files\Git\bin\git.exe" push --recurse-submodules=check --progress "origin ...

  3. Windows下干活儿辅助软件

    桌面下高速文件搜索软件:Listary Pro(收费)和Everything(开源免费),Everything推荐Beta版,明显比老旧的稳定版好用. 桌面太乱,可以试试Fences(收费). 需要文 ...

  4. C# Use Pop3Client to read gmail

    host = "pop.gmail.com" user = "xxxxx@gmail.com" password = "xxxx" port ...

  5. Eclipse调试时Application XXX is waiting for the debugger to attach的提示

    原文链接: http://blog.csdn.net/star_huang/article/details/7678845 最近Eclipse调试时总是出现Application XXX  is wa ...

  6. css3 定义选择器

    引言:CSS样式规则有两个主要部分.选择器决定将格式化应用到哪些元素.声明则定义要应用的格式化. 构造选择器 选择器可以定义五个不同的标准来选择要进行格式化的元素. 元素的类型或者名称.如下所示. h ...

  7. C++中文件按行读取和逐词读取 backup

    http://blog.csdn.net/zhangchao3322218/article/details/7930857 #include  <iostream>#include  &l ...

  8. CORS(跨来源资源共享协议) 与 http 302状态

    昨天遇到的问题 使用ajax请求一个支持CORS的跨域页面(A),此页面返回302状态并且重新定向到页面(B).此时ajax停止不前,并且触发 ajax onerror 事件. 正确的相应应该是:aj ...

  9. python-redis 入门

    redis官网http://redis.io Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. Redis是一 ...

  10. <转载> 优秀程序员必备的23条好习惯

    转自 优秀程序员必备的23条好习惯 编程是一项聪明人玩的游戏,它既是对智力的考验,也是对习惯的考验,智力的好坏取决于父母的基因,人们无从左右,但习惯的好坏却是可以不断培养.一项由美国芝加哥大学国家研究 ...