1.添加引用:
Aspose.Cells.dll(我们就叫工具包吧,可以从网上下载。关于它的操作我在“Aspose.Cells操作说明 中文版 下载 Aspose C# 导出Excel 实例”一文中的说。这里你暂时也可不理会它。)
即使没有安装office也能用噢,这是一个好强的大工具。
2.编写Excel操作类
using System;
using System.Collections.Generic;
using System.Text;
using Aspose.Cells;
using System.Data;
public class AsposeExcel
{
private string outFileName = "";
private string fullFilename = "";
private Workbook book = null;
private Worksheet sheet = null;
public AsposeExcel(string outfilename, string tempfilename) //导出构造数
{
outFileName = outfilename;
book = new Workbook();
// book.Open(tempfilename);这里我们暂时不用模板
sheet = book.Worksheets[0];
}
public AsposeExcel(string fullfilename) //导入构造数
{
fullFilename = fullfilename;
// book = new Workbook();
// book.Open(tempfilename);
// sheet = book.Worksheets[0];
}
private void AddTitle(string title, int columnCount)
{
sheet.Cells.Merge(0, 0, 1, columnCount);
sheet.Cells.Merge(1, 0, 1, columnCount);
Cell cell1 = sheet.Cells[0, 0];
cell1.PutValue(title);
cell1.Style.HorizontalAlignment = TextAlignmentType.Center;
cell1.Style.Font.Name = "黑体";
cell1.Style.Font.Size = 14;
cell1.Style.Font.IsBold = true;
Cell cell2 = sheet.Cells[1, 0];
cell1.PutValue("查询时间:" + DateTime.Now.ToLocalTime());
cell2.SetStyle(cell1.Style);
}
private void AddHeader(DataTable dt)
{
Cell cell = null;
for (int col = 0; col < dt.Columns.Count; col++)
{
cell = sheet.Cells[0, col];
cell.PutValue(dt.Columns[col].ColumnName);
cell.Style.Font.IsBold = true;
}
}
private void AddBody(DataTable dt)
{
for (int r = 0; r < dt.Rows.Count; r++)
{
for (int c = 0; c < dt.Columns.Count; c++)
{
DataRow dr = dt.Rows[r];
sheet.Cells[r + 1, c].PutValue(dr[c] + "");
}
}
}
//导出------------下一篇会用到这个方法
public Boolean DatatableToExcel(DataTable dt)
{
Boolean yn = false;
try
{
//sheet.Name = sheetName;
//AddTitle(title, dt.Columns.Count);
//AddHeader(dt);
AddBody(dt);
sheet.AutoFitColumns();
//sheet.AutoFitRows();
book.Save(outFileName);
yn = true;
return yn;
}
catch (Exception e)
{
return yn;
// throw e;
}
}
public DataTable ExcelToDatatalbe()//导入
{
Workbook book = new Workbook();
book.Open(fullFilename);
Worksheet sheet = book.Worksheets[0];
Cells cells = sheet.Cells;
//获取excel中的数据保存到一个datatable中
DataTable dt_Import = cells.ExportDataTableAsString(0, 0, cells.MaxDataRow + 1, cells.MaxDataColumn + 1, false);
// dt_Import.
return dt_Import;
}
}
3. Word导出
//设置文件类型
// saveFileDialog为一个对话框控件
//如果没有人工具栏中拉,
//可以:SaveFileDialog saveFileDialog1=new SaveFileDialog();
saveFileDialog1.Filter = "导出Excel (*.xls)|*.xls|Word (*.doc)|*.doc";
saveFileDialog1.FilterIndex = 1;
saveFileDialog1.RestoreDirectory = true;
saveFileDialog1.CreatePrompt = true;
saveFileDialog1.Title = "导出文件保存路径";
//saveFileDialog1.ShowDialog();
//string strName = saveFileDialog1.FileName;
//设置默认文件类型显示顺序
//saveFileDialog1.FilterIndex = 2;
//保存对话框是否记忆上次打开的目录
saveFileDialog1.RestoreDirectory = true;
//点了保存按钮进入
if (saveFileDialog1.ShowDialog() == DialogResult.OK)
{
//获得文件路径
string localFilePath = saveFileDialog1.FileName.ToString();
//获取文件名,不带路径
string fileNameExt = localFilePath.Substring(localFilePath.LastIndexOf("\\") + 1);
//获取文件路径,不带文件名
string FilePath = localFilePath.Substring(0, localFilePath.LastIndexOf("\\"));
//给文件名前加上时间
string newFileName = DateTime.Now.ToString("yyyyMMdd") + fileNameExt;
//在文件名里加字符
//saveFileDialog1.FileName.Insert(1,"dameng");
saveFileDialog1.FileName = FilePath + "\\" + newFileName;
System.IO.FileStream fs = (System.IO.FileStream)saveFileDialog1.OpenFile();//输出文件
StreamWriter writer = new StreamWriter(fs);
writer.Write("tttt");//这里就是你要导出到word的内容,内容是你什么你自已DIY
writer.Flush();
writer.Close();
fs.Close();
}
4. 导出datatable到excel
DataTable dt = null;
if (ds_all.Tables[0] != null)
{
dt = ds_all.Tables[0];
}
else {
MessageBox.Show("没有数据记录", "*^_^* 温馨提示信息", MessageBoxButtons.OK);
return;
}
//上面只是取datatable,你自己diy
AsposeExcel tt = new AsposeExcel(saveFileDialog1.FileName, "");//不用模板, saveFileDialog1是什么?上面已经说过
bool OK_NO = tt.DatatableToExcel(dt);
if (OK_NO)
{
MessageBox.Show("导出成功", "*^_^* 温馨提示信息", MessageBoxButtons.OK);
}
else
{
}
5. Excel导入(已经验证)
private void simpleButton3_Click(object sender, EventArgs e)
{
OpenFileDialog ofd = new OpenFileDialog();
ofd.Title = "Excel文件";
ofd.FileName = "";
ofd.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments);
ofd.Filter = "所有文件(*.*)|*.*|Excel2003文件(*.xls)|*.xls|Excel2007文件(*.xlsx)|*.xlsx";
//文件有效性验证ValidateNames,验证用户输入是否是一个有效的Windows文件名
ofd.ValidateNames = true;
//验证路径有效性
ofd.CheckFileExists = true;
//验证文件有效性
ofd.CheckPathExists = true;
string path = string.Empty;
if (ofd.ShowDialog() == DialogResult.OK)
{
path = ofd.FileName;
}
if (path == "")
{
MessageBox.Show("没有选择Excel文件,无法导入!");
return;
}
AsposeExcel tt = new AsposeExcel(path);
DataTable dt;
try
{
dt = tt.ExcelToDatatalbe();
//有了表格了
}
catch (Exception ex)
{
return;
}
}
分享到:
相关推荐
C# 操作 Excel 导入导出,很方便的.
C# Excel导入导出多sheet页
C#excel导入导出 1.调用了NPOI的dll来进行excel导入导出 2.不需要安装office 3.支持各种版本的excel文件 4.速度相对比较快。
C# Excel的导入导出,经网上摘抄加自己修改,项目绝对能运行成功,关于导出的方法来着于网上,具体实现不是很清楚,但是导出一个问题只能导出xls后缀名,不能导出xlsx后缀的,希望大家给点意见!
C# EXCEL导入导出类 /// /// 导入EXCEL到DataSet /// /// <param name="fileName">Excel全路径文件名 /// 导入成功的DataSet public DataSet ImportExcel(string fileName) /// /// 把DataTable导出...
C#调用NPOI进行Excel导入、导出。 文件为一个解决方案,包含了所有开发源码。 文章为:http://www.cnblogs.com/polk6/p/4425620.html
c#使用npoi导入导出Excel示例,支持asp.net core/asp.net,示例使用asp.Net core
C# Excel导入导出到DataGridView 在DataGridView中直接编辑保存Excel C#导入。导出。还有类库。。。
excel导入导出的问题并进行求和统计的问题困扰了好几天了,现在吐血分享给大家!!!!! 主要功能: 1.导出: 在页面加载的时候,将数据库数据绑定到页面gridview上, 按钮“导出excel”实现从页面导出excel文件, ...
c#制作的EX29-Excel导入导出功能。
c# 简单明了的EXCEL的导入及 导出 只需要修改DAL中conn的数据库连接字符串,不用再做其他修改 直接导入!导入EXCEL模板123.xls也在附件中!
简单通用的Excel导入导出,导入生成对应的DataTable,导出给出路径,直接生成文件。
C# Excel导入 Excel导出 VS2005 asp.net 速度挺快的
Excel导入分为3个步骤,1、获取.xls文件的路径(即选择目标文件) 2、选择sheet,每个excel都可以有多个sheet,我们获取第一个sheet...3、读取Excel表中的数据,在以下例子中,我把Excel中的表存为DataSet对象。 ......
C#实现导入导出Excel功能,基于NPOI的强类型Excel导入导出组件