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系统全面使用,效果不错,今天应 ...
随机推荐
- Window Server IIS6.0部署webservice请求调用提示请求失败
在一台window server 2003机器上部署了一个webservice,iis为6.0,奇怪的是.在服务器本机调用webservice成功了,可是在其它client调用却反馈失败.详细什么原因 ...
- Supervisor 的配置与使用
环境:ubuntu 14.04 lts http://supervisord.org/liunx 下有很多守护进程的工具,如 nohup,screen,supervisor 等,supervisor ...
- 删除.gitignore中的在version control中的文件
如果有一个文件例如xyz在版本控制系统中,然后你发现这个文件不应该提交到git上,所以加了.gitignore文件并将其加入其中,但是git不会自动讲其从版本库中移除它.如果你只有一个文件,你可以使用 ...
- Winform中进行MD5加密
Winform,c#进行MD5加密直接上步骤: 1.添加引用 2.在.NET选项卡中找到“System.Web” 3.选中之后,点击“确定”即可,此时会在解决方案中看到刚才添加的引用 4.引用名空间: ...
- C++ 类的静态成员详细讲解(转)
在C++中,静态成员是属于整个类的而不是某个对象,静态成员变量只存储一份供所有对象共用.所以在所有对象中都可以共享它.使用静态成员变量实现多个对象之间的数据共享不会破坏隐藏的原则,保证了安全性还可以节 ...
- 微信、qq时间格式模板
产品近来蛋疼,时间格式从做完到现在改了四遍了 ,最新的要求如下: * 2分钟内 无显示 * 2分钟-24小时 HH:mm * 昨天 昨天 HH:mm * 前天 前天 HH:mm * 今年 MM:DD ...
- Oracle数据库入门——如何根据物化视图日志快速刷新物化视图
Oracle物化视图的快速刷新机制是通过物化视图日志完成的.Oracle如何通过一个物化视图日志就可以支持多个物化视图的快速刷新呢,本文简单的描述一下刷新的原理. 首先,看一下物化视图的结构:SQL& ...
- Codeforces Round #184 (Div. 2) E. Playing with String(博弈)
题目大意 两个人轮流在一个字符串上删掉一个字符,没有字符可删的人输掉游戏 删字符的规则如下: 1. 每次从一个字符串中选取一个字符,它是一个长度至少为 3 的奇回文串的中心 2. 删掉该字符,同时,他 ...
- 本人第一个开源代码,NETSpider 网络蜘蛛采集工具
NETSpider网站数据采集软件是一款基于.Net平台的开源软件.软件部分功能是基本Soukey软件进行开发的.这个版本采用VS2010+.NET3.5进行开发的.NETSpider采摘当前提供的主 ...
- iOS 复选框做法
-(void)checkboxClick:(UIButton *)btn{ btn.selected = !btn.selected;} - (void)viewDidLoad {UIButto ...