文档章节

C# Excel导入导出

ggself
 ggself
发布于 2016/05/04 16:52
字数 812
阅读 46
收藏 0
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;
	}
}


本文转载自:http://zheyiw.iteye.com/blog/2028601

上一篇: C#代码 命名规范
下一篇: 字符串处理技巧
ggself
粉丝 0
博文 15
码字总数 0
作品 0
东城
私信 提问
Excel组件Spire.XLS 教程:将Excel导出到XML和XML导入Excel

Spire.XLS for .NET是一个专业的.NET Excel组件,通过Spire.XLS for .NET我们能够将Excel快速导出到Office Open XML,或者仅仅通过三个步骤将Office Open XML导入Excel。 导出/导入功能如下所...

可乐瓶的小辣椒
2017/11/02
39
0
web报表开发技术专题五:Excel的阴影

自从 n 年前 Excel 击败 Lotus ,独霸电子表格软件市场以来。所有的表格类软件都不能不充分考虑 Excel ,寻找 Excel 照顾不到的功能点。所有的表格类软件都要被迫考虑和 Excel 兼容,能够导入...

长平狐
2012/10/11
232
0
PHP导出excel编码的问题

php导出一个excel,导入另一款c#做的软件中,失败,如果把导出的excel另存编码为ascii格式或者直接给sheet重命名一下,就能导入成功,应该怎么解决? (php导出是用的hearder头的方式)...

jquery-php
2017/06/16
390
0
C#的Excel数据映射和转换--Npoi.Mapper

C#强类型和Excel数据相互映射和转换, 用于导入导出数据. 支持XLS和XLSX格式. 依赖于Npoi 2.1.3.1 功能点: 导入Excel数据到POCO; 导出数据到Excel; 基于列名和属性名的隐式映射, 可以不用写任...

dtian
2016/04/04
3.9K
1
怎么将officeexcel 2007内容转换成xml,自带开发工具导出 (图文详解)

因上面发了一份数据文件是用excel存储的,200多条数据, 需要加载到程序中。第一个就想到了copy ,想到自己想个机器一样copy,在留下一大堆垃圾代码。就果断pass 想到以前用c#可以读取excel...

补全
2012/07/04
2.7K
0

没有更多内容

加载失败,请刷新页面

加载更多

《JAVA核心知识》学习笔记 (21. JAVA 算法)

21. JAVA 算法

Shingfi
24分钟前
4
0
redis 命令

redis 秒杀用到的 原子锁 :$redis->decr('jili_reward_goods_stock_' . $gifts_id) redis 秒杀用到的原子锁在秒杀过程中库存量增加 $redis->incrBy('key1', 10); redis 键查看重复:$redis-......

小小小壮
24分钟前
4
0
像智能手机一样管理云端应用:阿里云联合微软全球首发开放应用模型(OAM)

2019 年 10 月 17 日上午 9 点 15 分,阿里巴巴合伙人、阿里云智能基础产品事业部总经理蒋江伟在 QCon 上海《基于云架构的研发模式演进》主题演讲中,正式宣布: “今天,我们同微软联合发布...

阿里巴巴云原生
33分钟前
4
0
SpringBoot配置数据源

默认数据源 Springboot默认支持4种数据源类型,定义在 org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration 中,分别是: org.apache.tomcat.jdbc.pool.DataSource......

Gx_ww
36分钟前
4
0
Java应用在docker环境配置容器健康检查

在《极速体验docker容器健康》一文已体验了docker容器健康检查功能,今天就来给java应用的容器加入健康检查,使应用的状态随时都可以被监控和查看。 实战环境信息 操作系统:macOS Catalina ...

程序员欣宸
38分钟前
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部