导出excel、word、csv文件方法汇总
http://www.woaic.com/2012/06/64
excel文件主要是输出html代码。以xls的文本格式保存文件。
生成excel格式的代码:
/// <summary>
/// 输出excel格式的html代码
/// </summary>
/// <param name="dt"></param>
/// <param name="fileName"></param>
/// <param name="tableHeader"></param>
/// <param name="UseDefinedHeader"></param>
/// <returns></returns>
public string MakeExcelStr(DataTable dt, string fileName, string[] tableHeader,bool UseDefinedHeader)
{
StringBuilder strResult = new StringBuilder();
int iColCount = dt.Columns.Count;
if (dt.Columns.Count == 0)
return strResult.ToString();
strResult.Append("<table cellspacing=\"0\" cellpadding=\"5\" rules=\"all\" border=\"1\">");
strResult.Append("<tr style=\"font-weight: bold; white-space: nowrap;\">");
if (UseDefinedHeader)//是否是用户自定义表头
{
for (int i = 0; i < tableHeader.Length; i++)
{
strResult.Append("<td style=\"text-align:center\">" + tableHeader[i] + "</td>");//让文本居中显示
}
}
else
{
for (int i = 0; i < iColCount; i++)
{
strResult.Append("<td style=\"text-align:center\">" + (dt.Columns[i] + "").ToString() + "</td>");
}
}
strResult.Append("</tr>");
foreach (DataRow dr in dt.Rows)
{
strResult.Append("<tr>");
for (int i = 0; i < iColCount; i++)
{
// style=\"vnd.ms-excel.numberformat:@\"
strResult.Append("<td style=\"vnd.ms-excel.numberformat:@\">'" + (dr[i] + "").ToString() + "</td>");//设置单元格是文本格式(防止文本是科学计算法,即E+***这种情况)
}
strResult.Append("</tr>");
}
strResult.Append("</table>");
return strResult.ToString();
}
把生成的excel格式的代码保存成excel文件的方法
/// <summary>
/// 导出excel表格
/// </summary>
/// <param name="dt"></param>
/// <param name="fileName"></param>
/// <param name="tableHeader">表头</param>
/// <param name="Defined">是否自定义表头</param>
private void ExprotToExcel(DataTable dt, string fileName, string[] tableHeader, bool Defined)
{
DogManage.Common.ExcelHelper excelHelper = new DogManage.Common.ExcelHelper();
string result = excelHelper.MakeExcelStr(dt, fileName, tableHeader,Defined);
HttpContext.Current.Response.Clear();
System.IO.StringWriter sw = new System.IO.StringWriter();
sw.Write(result);
sw.Close();
string str2 = HttpUtility.UrlEncode(fileName + "_" + DateTime.Now.ToString("yyyy-MM-dd"));
HttpContext.Current.Response.AddHeader("Content-Disposition", "attachment; filename=" +str2 + ".xls");
HttpContext.Current.Response.ContentType = "application/ms-excel";
HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("UTF-8");
HttpContext.Current.Response.Write(sw);
HttpContext.Current.Response.End();
}
生成word的代码:
private void exportword()
{
Response.Clear();
Response.Buffer = true;
Response.Charset = "utf-8";
Response.AppendHeader("Content-Disposition", "attachment;filename=tmp.doc");
Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8");
Response.ContentType = "application/ms-word";
this.EnableViewState = false;
System.IO.StringWriter oStringWriter = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter oHtmlTextWriter = new System.Web.UI.HtmlTextWriter(oStringWriter);
oHtmlTextWriter.WriteLine(hf.Value);
Response.Write(oStringWriter.ToString());
Response.End();
}
csv文件就是一个有特定格式的字符串拼接出来的文件,每个列通过,分割开来。换行则两外输出一行文本就行了
生成csv文件的代码:
/// <summary>
/// 输出csv文件的代码
/// </summary>
/// <param name="dt"></param>
/// <param name="fileName"></param>
/// <param name="tableHeader">表头</param>
/// <returns></returns>
public string MakeCSVStr(DataTable dt, string fileName, string[] tableHeader)
{
StringBuilder strResult = new StringBuilder();
string temp = string.Empty;
int iColCount = dt.Columns.Count;
if (iColCount == 0)
return strResult.ToString();
for (int i = 0; i < iColCount; i++)
{
temp+="\"" + dt.Columns[i] + "\"";
if (i < iColCount - 1)
temp+=",";
}
strResult.AppendLine(temp);
foreach (DataRow dr in dt.Rows)
{
temp = "";
for (int i = 0; i < iColCount; i++)
{
if (!Convert.IsDBNull(dr[i]))
temp+="\"" + dr[i].ToString() + "\"";
else
temp += "\"\"";
if (i < iColCount - 1)
temp+=",";
}
strResult.AppendLine(temp);
}
return strResult.ToString();
}
导出csv文件的方法:
/// <summary>
/// 导出csv文件
/// </summary>
/// <param name="dt"></param>
/// <param name="fileName"></param>
/// <param name="tableHeader">表头</param>
/// <param name="Defined">是否自定义表头</param>
private void ExprotToCSV(DataTable dt,string fileName, string[] tableHeader)
{
DogManage.Common.ExcelHelper excelHelper = new DogManage.Common.ExcelHelper();
string result=excelHelper.MakeCSVStr(dt, fileName, tableHeader);
HttpContext.Current.Response.Clear();
System.IO.StringWriter sw = new System.IO.StringWriter();
sw.Write(result);
sw.Close();
HttpContext.Current.Response.AddHeader("Content-Disposition", "attachment; filename=" + fileName + ".csv");
HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";
HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
HttpContext.Current.Response.Write(sw);
HttpContext.Current.Response.End();
}
导出excel、word、csv文件方法汇总的更多相关文章
- PHP导出数据到CSV文件函数/方法
如果不清楚什么是CSV文件,可看如下文章介绍 CSV格式的是什么文件?CSV是什么的缩写? /** * 导出数据到CSV文件 * @param array $data 数据 * @param arr ...
- (转载)DBGridEh导出Excel等格式文件
DBGridEh导出Excel等格式文件 uses DBGridEhImpExp; {--------------------------------------------------------- ...
- Excel打开csv文件乱码问题的解决办法
excel打开csv 出现乱码怎么解决 https://jingyan.baidu.com/article/ac6a9a5e4c681b2b653eacf1.html CSV是逗号分隔值的英文缩写,通 ...
- js原生导出excel和csv
严格意义来说并不是真正的excel文件,只是可以用excel打开查看而已,实际上的格式是逗号分隔文件即csv文件. 这里有几个坑要说一下: 不加Unicode的utf8头部标识excel打开文件会 ...
- mysql导出数据到csv文件
在日常工作中经常会遇见导出表中的数据到csv文件的操作,这里就简单总结一下导出的操作. 下面对csv文件的描述是摘录: 据RFC4180文档设置的,该文档全称Common Format and MIM ...
- PHP导出数据到CSV文件函数 csv_export()
后台往往需要导出各种数据到 Excel文档中.通常我们是导出 .csv文件格式,PHP导出函数参考代码如下: /** * 导出数据到CSV文件 * * @param array $data 二维数组( ...
- PHP导出数据到CSV文件
后台往往需要导出各种数据到 Excel文档中.通常我们是导出 .csv文件格式,PHP导出函数参考代码如下: /** * 导出数据到CSV文件 * * @param array $data 二维数组( ...
- DataGird导出EXCEL的几个方法
DataGird导出EXCEL的几个方法(WebControl) using System;using System.Data;using System.Text;using System.Web;u ...
- excel打开csv文件乱码解决办法
参考链接: https://jingyan.baidu.com/article/4dc408484776fbc8d846f168.html 问题:用 Excel 打开 csv 文件,确认有乱码的问题. ...
随机推荐
- RHCSA_DAY07
echo $PATH 用户账号管理 用户账号的作用:用户账号可用来登录系统,可以实现访问控制 用户模板目录:/etc/skel/ [root@localhost ~]# ls -a /etc/skel ...
- [C++]-vector 向量
什么是向量容器 向量容器是一种支持高效的随机访问和高效的尾部插入新元素的容器. 向量容器一般实现为一个动态分配的数组,向量中的元素连续的存放在这个数组中,因此对向量容器进行随机访问具有和动态访问动态数 ...
- MySQL:JDBC批量插入数据的效率
平时使用mysql插入.查询数据都没有注意过效率,今天在for循环中使用JDBC插入1000条数据居然等待了一会儿 就来探索一下JDBC的批量插入语句对效率的提高 首先进行建表 create tabl ...
- 在Ant脚本中使用时间戳
时间戳在项目自动构建中广泛使用,例如在jar文件的manifest文件中,以及最后zip包的文件名里等,时间戳对应的Ant命令是,这个标签既可以用在一个内部,也可以放在外部用作"全局&quo ...
- Java和Groovy脚本互相调用实例
本实例是GODU动态脚本的一个技术简化版,演示了java调groovy,groovy又调java的运行过程. 测试用例: package com.boco.godu.integration; impo ...
- HTML重点总结
HTML基础 1. 标题 HTML 标题(Heading)是通过<h1> - <h6> 标签来定义的. <h1>这是一个标题</h1> <h2&g ...
- docker-01
Docker介绍 1 什么是容器? Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源 Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移 ...
- 单片机学习(八)点阵LED的使用
目录 一.点阵LED的理论知识 1. 点阵屏的打开方式 2. LED点阵简介 3. 点阵LED的结构和操作方式 4. 74HC595模块 PPT上的简介 串行转并行的工作原理 二.编码实现 1. C5 ...
- 题解 c(留坑)
传送门 这题卡常--而且目前还没有卡过去 首先以原树重心为根,向所有子树重心连边,可以建立一棵点分树 点分树有两个性质: 一个是树高只有log层 另一个是两点在点分树上的lca一定在原树上两点间的树上 ...
- SpringCloud之Config
1.背景 在前的学习中,我们几乎解决了springCloud的所有常规应用,但是大家有没有想过这样一个问题: 是使用微服务后,有非常多的application.yml文件,每个模块都有一个,实际开发中 ...