`
zheyiw
  • 浏览: 1020236 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

C#Excel导入导出

    博客分类:
  • C#
阅读更多
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的导入导出功能。 首先,我们需要知道在C#中操作Excel有两种主要方式:一是使用Microsoft.Office.Interop.Excel库,它允许直接调用Excel应用程序的COM接口;二是使用第三方库,如...

    C# Excel导入导出

    本项目“C# Excel导入导出”正是基于NPOI实现的,旨在展示如何使用C#调用NPOI进行Excel的数据导入与导出操作。 1. **NPOI简介** NPOI提供了一个与Microsoft Office.Interop.Excel类似的API,但无需在服务器端安装...

    c#Excel导入导出

    通过这个C# Excel导入导出示例,你可以学习到如何在ASP.NET Core应用程序中利用NPOI库高效地处理Excel数据。结合提供的项目文件(ExcelDemo.sln、ExcelDemo、ExcelInOutput),你将能够看到完整的实现,进一步理解...

    C# Excel 导入 导出

    在C#编程中,Excel的导入与导出是常见的数据操作任务,特别是在处理大量结构化数据时。这里我们将深入探讨如何使用C#实现Excel文件的读取和写入,主要针对Excel 2007及以后版本(xlsx格式)。 首先,C#本身并不直接...

    C# EXCEL导入导出类

    根据提供的文件信息,本文将详细解释C#中用于Excel导入导出的相关知识点,包括关键方法的实现原理与应用场景。 ### C# Excel导入导出类详解 #### 一、概述 在实际开发过程中,经常会遇到需要读取或写入Excel文件...

    基于Aspose的简单通用C#Excel导入导出

    在IT行业中,数据处理是一项至...总的来说,基于Aspose的C# Excel导入导出实现是一个实用的工具,它能够提高开发效率,使得数据处理变得更加便捷。无论是数据分析、报表生成还是数据交换,都能够利用此类工具高效完成。

    C# Excel导入导出多sheet页

    总之,C#中处理多sheet页的Excel导入导出涉及选择合适的库、创建和操作工作簿、读取和写入单元格以及处理不同数据类型。`Microsoft.Office.Interop.Excel`提供了与Excel应用程序的紧密集成,而`Aspose.Cells`提供了...

    C#excel导入导出

    通过NPOI库,C#开发者可以轻松地处理Excel文件的导入和导出,实现数据的读写,无需依赖Microsoft Office的安装。提供的示例代码可以帮助你快速入门,但实际应用中可能需要根据具体需求进行调整和优化。如果你在Demo...

    C#通用Excel导入导出工具类

    本篇文章将深入探讨“C#通用Excel导入导出工具类”的实现原理及应用,主要涉及的技术点包括反射、特性以及如何创建一个高效的Excel导入导出解决方案。 首先,我们要理解反射在C#中的作用。反射是一种强大的机制,它...

    C# excel导入导出 宏求和统计

    excel导入导出的问题并进行求和统计的问题困扰了好几天了,现在吐血分享给大家!!!!! 主要功能: 1.导出: 在页面加载的时候,将数据库数据绑定到页面gridview上, 按钮“导出excel”实现从页面导出excel文件, ...

    C# excel导入导出

    在.NET开发环境中,C#是一种常用的...以上就是关于C#中Excel导入导出的主要知识点,包括使用不同的库、与数据库的交互、模板文件的应用以及性能优化。通过掌握这些技术,你可以有效地处理Excel数据,提升数据处理效率。

    C#实现Excel导入导出功能

    总的来说,"ExcelReardWriteCSharpDemo"项目展示了C#如何通过第三方库与Excel进行交互,完成数据的导入导出操作,这对于任何需要处理Excel数据的系统来说都是一个非常实用的功能。通过学习和理解这个Demo,开发者...

    C# Excel导入导出,基于NOPI(兼容xls和xlsx)

    本教程主要讲解如何使用C#结合NPOI库进行Excel的导入导出操作。 首先,为了开始使用NPOI,你需要在你的项目中添加NPOI的引用。你可以通过NuGet包管理器进行安装,搜索"NPOI"并安装相应的包。 1. **导入Excel数据到...

    C#EXCEL导入导出实例

    这包括但不限于选择Excel文件、指定工作表、设置数据映射以及执行导入导出操作。 在代码部分,我们看到了一个名为`GetExcelDataTable`的方法,这个方法的核心作用是将Excel文件读取为一个`DataTable`对象。这个方法...

    C# Excel表的导入导出 类和详细配置方法

    本篇文章将详细介绍如何使用C#进行Excel表的导入操作,包括获取文件路径、选择工作表(Sheet)以及读取数据到DataSet对象。我们将使用Microsoft.Office.Interop.Excel库以及OleDb连接来实现这一过程。 首先,我们...

Global site tag (gtag.js) - Google Analytics