将DataTable内容导出到Excel表格的两种方法
方法一:循环DataTable单元格内容拼接字符串,利用StreamWriter的Write方法将字符串写入Excel文件中
这种方法很实现很简单。拼接字符串时,每个单元格之间添加'\t'(表示一个占位符,相当于Tab键),每行之间添加"\r\n"(表示换行)。
但是这种方法不能设置Excel单元格样式
1、定义一个方法GetSavePath(),利用SaveFileDialog控件选择Excel文件要保存的路径。
private string GetSavePath()
{
using (SaveFileDialog savePath = new SaveFileDialog())
{
savePath.Title = "选择要保存的路径和文件名";
savePath.Filter = "Excel 97-2003|*.xls";
savePath.RestoreDirectory = true; //是否记录上次选择的路径
savePath.FileName = "导出的表格";
if (savePath.ShowDialog() == DialogResult.OK)
{
return savePath.FileName; //返回Excel文件的保存路径和名字
}
return "Cancel";
}
}
2、定义一个方法GetSWstr(),将DataTable内容转换成字符串。
private string GetSWstr(DataTable table2)
{
StringBuilder strHead = new StringBuilder ();
//先添加每列标题
; i < table2.Columns.Count; i++)
{
strHead.Append(table2.Columns[i].Caption.Trim() + '\t');
}
strHead.Append("\r\n");
//再依次添加每行内容
; i < table2.Rows.Count; i++)
{
; j < table2.Columns.Count; j++)
{
strHead.Append(table2.Rows[i][j].ToString().Trim() + '\t');
}
strHead.Append("\r\n");
}
return strHead.ToString();
}
3、定义一个方法 WriteToExcel(),将内容写入Excel文件
public string WriteToExcel(String str, string filePath)
{
try
{
using (StreamWriter sw = new StreamWriter(filePath, false, System.Text.Encoding.Default)) //写入流
{
sw.Write(str);
}
return "导出Execl成功!";
}
catch (Exception ex)
{
return "导出Execl失败!原因:" + ex.Message;
}
}
4、调用WriteToExcel
WriteToExcel(GetSWstr(table), GetSavePath());
方法二:利用COM组件实现Excel操作,可以设置Excel格式
这种操作也很简单,在定义好excel对象后,可以通过 excel.Cells[i, j]=? 对某一个单元格赋值。
也可以通过 range = excel.Range[excel.Cells[i, 1], excel.Cells[i, 3]]; 获取一个单元格区域,然后设置range的属性就可以设置单元格样式或值
range.MergeCells = true; //合并单元格
range.Value = "标题";
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
Microsoft.Office.Interop.Excel.Workbook book = excel.Workbooks.Add(true);
Microsoft.Office.Interop.Excel.Range range = null;
try
{
//第一行的第一列到第六列
range = excel.Range[excel.Cells[, ], excel.Cells[, ]];
range.MergeCells = true; ///合并单元格
range.Font.Bold = true; //黑体
range.Font.Size = ; //20号字体
range.HorizontalAlignment = XlHAlign.xlHAlignCenter; //水平居中
range.Value = "产品工序分解表"; //合并单元格的值
}
catch(Exception ex)
{
return "导出失败!错误原因:" + ex.Message;
}
finally
{
book = null;
range = null;
GC.Collect();
GC.WaitForPendingFinalizers();
excel.Quit();
excel = null;
}
将DataTable内容导出到Excel表格的两种方法的更多相关文章
- .NET环境下导出Excel表格的两种方式和导入两种类型的Excel表格
一.导出Excel表格的两种方式,其中两种方式指的是导出XML数据类型的Excel(即保存的时候可以只需要修改扩展名为.xls)和真正的Excel这两种. using System; using Sy ...
- js如何动态创建表格(两种方法)
js如何动态创建表格(两种方法) 一.总结 一句话总结: 1.方法一:写好创建表格的html代码,将之赋值给div的innerHTML. 2.方法二.直接用创建好的table元素的方法insertRo ...
- 用easyui实现查询条件的后端传递并自动刷新表格的两种方法
用easyui实现查询条件的后端传递并自动刷新表格的两种方法 搜索框如下: 通过datagrid的load方法直接传递参数并自动刷新表格 通过ajax的post函数传递参数并通过loadData方法将 ...
- .NET CORE 2.1 导出excel文件的两种方法
最近在做 MVC 项目的时候遇到项目的导出,下面总结下两种导出到excel 的方法 第一种方法: 将文件写到本地,然后返回这个File 或者返回这个 File 的绝对地址 其中 _hostingE ...
- LayUI使用弹窗重载父级数据表格的两种方法
参考LayUI官方文档,在子窗口中重载父级数据表格找到以下两种方法: 1.子窗口中重载:在子窗口中直接调用父级talbe的reload方法. $("body").on(" ...
- C#将数据集DataSet中的数据导出到EXCEL文件的几种方法
using System; using System.Collections.Generic; using System.Text; using System.Data; using System.W ...
- Java导出Excel文件的两种方法
将数据以Excel表格的形式导出:首先下载poi的jar包,导入项目中,或者使用maven仓库管理,在pom文件添加:<dependency> <groupId>org. ...
- mysql导出csv/excel文件的几种方法,mysql的load导入csv数据
方法一 php教程用mysql的命令和shell select * into outfile './bestlovesky.xls' from bestlovesky where 1 order by ...
- delphi 导出到excel的第1种方法
第一种方法delphi 快速导出excel uses ComObj,clipbrd; function ToExcel(sfilename:string; ADOQuery:TADOQuery):bo ...
随机推荐
- 手游client思考框架
手游新公司新项目client我不太同意框架.虽然我也终于让步,当他居然问老板,使这个幼稚的行为而悔恨. 然而,就在最近我写了一些代码视图,我更坚定了自己的想法和思想.和思路不一定适合其它人,所以我并不 ...
- Group By去除重复数据
今天在写一个sql,目的是去除表里某一个字段相同的数据,只保留最新的一条.之前group by 用的少.特此记录一下. SELECT * FROM litb_approval_task SELECT ...
- JNLP(Java Web Start )(转)
JNLP(Java Network Launching Protocol )是java提供的一种可以通过浏览器直接执行java应用程序的途径,它使你可以直接通过一个网页上的url连接打开一个java应 ...
- asp.net学习之再论sqlDataSource
原文:asp.net学习之再论sqlDataSource 本节从上一节没有阐述的几个方面,再讨论一下SqlDataSource的用法及注意的事项. 上一节的链接地址如下:http://www. ...
- NSOJ 飞船汇合(经典)
一支分散的飞船舰队,需要汇合到主舰,但是这种飞船在太空中飞行的耗油与质量没有关系,只与发动机打开的时间有关系,为了节省油量,指挥官通知,汇合途中,多台飞船可以串成串飞行,这样只需启动一台发动机,由于安 ...
- 10个devexpress ASPxPivotGrid常见问题
原文:10个devexpress ASPxPivotGrid常见问题 1.DXperience ASPxGridView如何开启lightweight模式 描述:ASPxGridView样式主题中pa ...
- NPOI实现Excel导入导出
NPOI实现Excel的导入导出,踩坑若干. Cyan是博主[Soar360]自2014年以来开始编写整理的工具组件,用于解决现实工作中常用且与业务逻辑无关的问题. 什么是NPOI? NPOI 是 P ...
- node.js高效操作mongodb
node.js高效操作mongodb Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为Jav ...
- CSharp设计模式读书笔记(7):适配器模式(学习难度:★★☆☆☆,使用频率:★★★★☆)
适配器模式(Adapter Pattern):将一个接口转换成客户希望的另一个接口,使接口不兼容的那些类可以一起工作,其别名为包装器(Wrapper).适配器模式既可以作为类结构型模式,也可以作为对象 ...
- jquery+css3打造一款ajax分页插件
原文:[原创]jquery+css3打造一款ajax分页插件 最近公司的项目将好多分页改成了ajax的前台分页以前写的分页插件就不好用了,遂重写一个 支持IE6+,但没有动画效果如果没有硬需求,个人认 ...