DataTable导出到Excel(.NET 4.0)
最近在论坛里又看到很多关于DataTable(DataSet)导入Excel的帖子,我也温故知新一下,用VS2010重新整理了一个Sample。这个问题简化一下就是内存数据到文件,也就是遍历赋值,只不过文件是有特殊格式的Excel,因此不能像一般的文本文件处理。另外,还有一种叫CSV的文件(用逗号分隔的文件,扩展名为.csv),因为默认用Excel打开的,网友也往往把这种文件误当做Excel文件。其实一个通过Excel COM对象作成Excel文件,一个通过一般的IO处理,他们的作成过程是完全不一样的。
先来看看Sample的结构: Form_Load的时候读取DB,绑定到DataGridView。按下"Data2Excel"按钮导出Excel文件(*.xls文件), 按下”Data2CSV”按钮导出CSV文件(*.csv文件)

其实CSV文件用文本文件可以直接打开,看下图,就是逗号分隔的文件,直接通过StringBuilder构造每一行字符串,最后通过System.IO.File.WriteAllText就可以了。

而关于Excel的操作,有两种方式,一种通过Cell一个一个单元格赋值,还有一种通过系统剪切板通过粘贴的方式赋值。因为跨托管域赋值,第一种赋值方式效率很低,原因嘛,可以看看这里:《.NET操作Excel COM对象》。所以Sample里选择了第二种方式。
另外,.NET 4.0里C#终于可以用上像VB.NET的可选参数了 T_T 真是省不少事啊,以前C#操作Excel都要写上很多System.Reflection.Missing.Value呢。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.IO;
using System.Runtime.InteropServices;
using System.Reflection;
using Excel = Microsoft.Office.Interop.Excel;
namespace DataExportLib
{
/// <summary>
/// 数据导出工具类
/// 前提:Microsoft Office 11.0 Object Library
/// .NET Framework 4.0
/// </summary>
public class DataExportUtils
{
public static void Export2Xls(DataTable data, string filename, bool exportHeader = true)
{
if (System.IO.File.Exists(filename))
System.IO.File.Delete(filename);
Excel._Application xlsApp = null;
Excel._Workbook xlsBook = null;
Excel._Worksheet xstSheet = null;
try
{
xlsApp = new Excel.ApplicationClass();
xlsBook = xlsApp.Workbooks.Add();
xstSheet = (Excel._Worksheet)xlsBook.Worksheets[1];
var buffer = new StringBuilder();
if (exportHeader)
{
// Excel中列与列之间按照Tab隔开
foreach (DataColumn col in data.Columns)
buffer.Append(col.ColumnName + "/t");
buffer.AppendLine();
}
foreach (DataRow row in data.Rows)
{
foreach (DataColumn col in data.Columns)
buffer.Append(row[col].ToString() + "/t");
buffer.AppendLine();
}
System.Windows.Forms.Clipboard.SetDataObject("");
// 放入剪切板
System.Windows.Forms.Clipboard.SetDataObject(buffer.ToString());
var range = (Excel.Range)xstSheet.Cells[1, 1];
range.Select();
xstSheet.Paste();
// 清空剪切板
System.Windows.Forms.Clipboard.SetDataObject("");
xlsBook.SaveAs(filename);
}
finally
{
if (xlsBook != null)
xlsBook.Close();
if (xlsApp != null)
xlsApp.Quit();
// finally里清空Com对象
Marshal.ReleaseComObject(xlsApp);
Marshal.ReleaseComObject(xlsBook);
Marshal.ReleaseComObject(xstSheet);
xstSheet = null;
xlsBook = null;
xlsApp = null;
}
}
public static void Export2CSV(DataTable data, string filename, bool exportHeader = true)
{
if (File.Exists(filename))
File.Delete(filename);
var buffer = new StringBuilder();
if (exportHeader)
{
for (var i = 0; i < data.Columns.Count; i++)
{
buffer.AppendFormat("/"{0}/"", data.Columns[i].ColumnName);
if (i < data.Columns.Count - 1)
buffer.Append(",");
}
buffer.AppendLine();
}
for (var i = 0; i < data.Rows.Count; i++)
{
for (var j = 0; j < data.Columns.Count; j++)
{
buffer.AppendFormat("/"{0}/"", data.Rows[i][j].ToString());
if (j < data.Columns.Count - 1)
buffer.Append(",");
}
buffer.AppendLine();
}
File.WriteAllText(filename, buffer.ToString(), Encoding.Default);
}
public static void Export2Xls<T>(List<T> data, string filename, bool exportHeader = true)
{
if (File.Exists(filename))
File.Delete(filename);
Excel._Application xlsApp = null;
Excel._Workbook xlsBook = null;
Excel._Worksheet xstSheet = null;
var type = typeof(T);
var properties = type.GetProperties();
var buffer = new StringBuilder();
if (exportHeader)
{
xlsApp = new Excel.ApplicationClass();
xlsBook = xlsApp.Workbooks.Add();
xstSheet = (Excel._Worksheet)xlsBook.Worksheets[1];
if (exportHeader)
{
foreach (var property in properties)
buffer.Append(property.Name + "/t");
buffer.AppendLine();
}
foreach (var row in data)
{
foreach (var property in properties)
buffer.Append(property.GetValue(row, null) + "/t");
buffer.AppendLine();
}
System.Windows.Forms.Clipboard.SetDataObject("");
// 放入剪切板
System.Windows.Forms.Clipboard.SetDataObject(buffer.ToString());
var range = (Excel.Range)xstSheet.Cells[1, 1];
range.Select();
xstSheet.Paste();
// 清空剪切板
System.Windows.Forms.Clipboard.SetDataObject("");
xlsBook.SaveAs(filename);
}
}
public static void Export2CSV<T>(List<T> data, string filename, bool exportHeader = true)
{
if (File.Exists(filename))
File.Delete(filename);
var type = typeof(T);
var properties = type.GetProperties();
var buffer = new StringBuilder();
if (exportHeader)
{
for (var i = 0; i < properties.Length; i++)
{
buffer.AppendFormat("/"{0}/"", properties[i].Name);
if (i < properties.Length - 1)
buffer.Append(",");
}
buffer.AppendLine();
}
for (var i = 0; i < data.Count; i++)
{
for (var j = 0; j < properties.Length; j++)
{
buffer.AppendFormat("/"{0}/"", properties[j].GetValue(data[i], null).ToString());
if (j < properties.Length - 1)
buffer.Append(",");
}
buffer.AppendLine();
}
File.WriteAllText(filename, buffer.ToString());
}
}
}
转自:http://blog.csdn.net/fangxing80/article/details/6099621
DataTable导出到Excel(.NET 4.0)的更多相关文章
- DataTable导出到Excel
简单的导出到Excel中: 代码如下: using System; using System.Collections.Generic; using System.Data; using System. ...
- [转].net 使用NPOI或MyXls把DataTable导出到Excel
本文转自:http://www.cnblogs.com/yongfa365/archive/2010/05/10/NPOI-MyXls-DataTable-To-Excel-From-Excel.ht ...
- DataTable 导出到 Excel 类
底层类: #region DataTable 导出到 Excel /// <summary> /// DataTable 导出到 Excel /// </summary> // ...
- c# DataTable导出为excel
/// <summary> /// 将DataTable导出为Excel文件(.xls) /// </summary> /// <param name="dt& ...
- C# datatable 导出到Excel
datatable导出到Excel /// <summary> /// 将DataTable导出为Excel文件(.xls) /// </summary> /// <pa ...
- NPOI使用Datatable导出到Excel
首先要引用dll 下载地址:http://pan.baidu.com/s/1dFr2m 引入命名空间: using NPOI.HSSF.UserModel;using NPOI.SS.UserMode ...
- C# 将datatable导出成Excel
public void Result( ){try{StringBuilder sql = new StringBuilder();List<SqlParameter> parameter ...
- csv/json/list/datatable导出为excel的通用模块设计
导出excel的场景我一般都是一个List直接导出成一张sheet,用Npoi.Mapper库很方便,最近我经常是需要将接口返回的jsonarray转成一张excel表,比如从elasticsearc ...
- 将DataTable导出为Excel C#
/// <summary> /// 导出Excel /// </summary> /// <param name="dt">DataTable& ...
随机推荐
- CentOS6.5下 yum安装LAMP
CentOS下yum安装LAMP 1. 用yum安装Apache,Mysql,PHP. 1.1安装Apache yum install httpd httpd-devel 安装完成后,用/etc/ ...
- 由底层和逻辑说开去——c++之类与对象的深入剖析
类是什么,对象是什么, 这两个问题在各个c++书里面都以一种抽象的描述方式,给了我们近乎完美的答案,然后我好像就知道什么是类什么是对象了,但是当扪心自问,类在哪儿,对象在哪儿,成员方法在哪儿,成员变 ...
- List<t>中如何将指定元素的值放到第一位
public static List<GCountryExtend> GetList() { try { var result = new List<GCountryExtend&g ...
- [SQL SERVER系列]之嵌套子查询和相关子查询
子查询有两种类型,一种是只返回一个单值的子查询,这时它可以用在一个单值可以使用的地方,这时子查询可以看作是一个拥有返回值的函数:另外一种是返回一列值的子查询,这时子查询可以看作是一个在内存中临时存在的 ...
- python学习笔记26(python中__name__的使用)
在python中,每个py文件都是一个模块,也都是一个可执行文件,即包含main方法.因此,对每个py文件,可以单独运行,也可以import它给其他客户使用,这两种情况不一样. 1. 如果模块是被导入 ...
- bnuoj 29375 Two Strings(字符串?)
http://www.bnuoj.com/bnuoj/problem_show.php?pid=29375 [题意]:可以对两字符串进行如下操作: 1.可以无损耗交换相邻两个字符(可以理解成交换任意字 ...
- 在 Windows 8 或 8.1 上安装 .NET Framework 3.5 安装错误:0x800f0906、0x800F081F
昨天给一天新装Windows 8.1的PC装.NET Framework 3.5 发现联网速度很慢,并且在长久等待过后直接报错了:0x800f0906 经过Bing,发现了解决方案: 如果根据需要安装 ...
- xfire for web-Service
1.0 XFire XFire是codeHaus组织提供的一个开源框架,它构建了POJO和SOA之间的桥梁,主要特性就是支持将POJO通过非常简单的方式发布成Web服务,这种处理方式不仅充分发挥了PO ...
- [转载]jquery ajax/post/get 传参数给 mvc的action
jquery ajax/post/get 传参数给 mvc的action 1.ActionResult Test1 2.View Test1.aspx 3.ajax page 4.MetaO ...
- C#跳出循环的几种方法的区别
break是循环结束执行,执行循环体后面的代码. continue是跳过本次循环未执行的代码,继续执行下一次循环. goto是跳到指定的指令去,你指哪,他跳到哪. return是函数返回,如果循环在M ...