C#中 导入和导出Excel的方法
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的方法的更多相关文章
- Java中导入、导出Excel
原文:Java中导入.导出Excel 一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已 ...
- 我是陌生人 Java中导入、导出Excel
我是陌生人 Java中导入.导出Excel 一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是: ...
- [转]Java中导入、导出Excel
原文地址:http://blog.csdn.net/jerehedu/article/details/45195359 一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样 ...
- 在mvc4中上传、导入和导出excel表方法总结
通过excel的导入导出练习,使用NPOI组件还是方便一点,所有下面就以NPOI下的导入导出给出实例,通过网页导入excel表,首先上传,再导入数据到库,这里为了方便就不导入到库中了,直接拿到数据.导 ...
- asp.net中导出Excel的方法
一.asp.net中导出Excel的方法: 本文转载 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出 ...
- Java中使用poi导入、导出Excel
一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际 ...
- 前端必读3.0:如何在 Angular 中使用SpreadJS实现导入和导出 Excel 文件
在之前的文章中,我们为大家分别详细介绍了在JavaScript.React中使用SpreadJS导入和导出Excel文件的方法,作为带给广大前端开发者的"三部曲",本文我们将为大家 ...
- 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; ...
- 分享我基于NPOI+ExcelReport实现的导入与导出EXCEL类库:ExcelUtility (续3篇-导出时动态生成多Sheet EXCEL)
ExcelUtility 类库经过我(梦在旅途)近期不断的优化与新增功能,现已基本趋向稳定,功能上也基本可以满足绝大部份的EXCEL导出需求,该类库已在我们公司大型ERP系统全面使用,效果不错,今天应 ...
随机推荐
- 20个最漂亮的基于WordPress的企业网站
20个最漂亮的基于WordPress的企业网站 每个人都知道很好很强大的WordPress是开源的,并且有一个很强的的团队和更强大的支持社区.它被世界上的广大设计师.程序员和商业人员广泛使用.它已经成 ...
- java web项目启动时自动加载自定义properties文件
首先创建一个类 public class ContextInitListener implements ServletContextListener 使得该类成为一个监听器.用于监听整个容器生命周期的 ...
- MediaPlayer 播放assets 文件夹下面的视频报错
Android MediaPlayer 播放assets 文件夹下面的视频报错 报下面的错: java.io.FileNotFoundException: This file can not be o ...
- 介绍几个工作开发中封装的好用的android自定义控件
首先看效果图, 看下这两个界面,第一个中用到了一个自定义的FlowRadioGroup,支持复合子控件,自定义布局: 第二个界面中看到了输入的数字 自动4位分割了吧:也用到了自定义的DivisionE ...
- Gradle 脚本剪片---copy
Gradle是以Groovy语言为基础,基于DSL语法的自动化构建工具,一个构建脚本能够包含任何Groovy语言元素,每个脚本都是UTF-8编码的文件. 6-1 Project对象API 前面我们说过 ...
- coreseek 提示 client version is higher than daemon version 解决办法
安装好coreseek,开启了服务之后,通过 sphinx php扩展去请求数据,提示:client version is higher than daemon version (client is ...
- Windows上使用clang编译
- 先自己从源代码 (http://llvm.org/releases/) 编译llvm和clang,或者直接安装clang for Windows - 测试过使用cygwin (https://cy ...
- codeforces B. Friends and Presents(二分+容斥)
题意:从1....v这些数中找到c1个数不能被x整除,c2个数不能被y整除! 并且这c1个数和这c2个数没有相同的!给定c1, c2, x, y, 求最小的v的值! 思路: 二分+容斥,二分找到v的值 ...
- AC_Dream 1224 Robbers(贪心)
题意:n个抢劫犯分别抢到的金钱是k1, k2, k3,...,一共得到的金钱是m, 但是在分钱的时候是按照x1/y, x2/y, x3/y,....的比例进行分配的!这样的话 一些抢劫犯就会觉得不公平 ...
- ubuntu启动器和dash里应用图标不正常
在以下目录: /usr/share/applications~/.local/share/applications 添加或编辑(pycharm图标不正常):jetbrains-pycharm.desk ...