使用Aspose.Cells实现导入导出

本文实例为大家分享了Aspose.Cells实现导入导出的具体代码,供大家参考,具体内容如下

这是自己整理的导入导出类,里面有注释。

using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Aspose.Cells;
namespace Lzd.Mvc.EasyUi.Common.ExcelUtil
{
  ///
  /// excel操作基类
  ///
  ///
 public  class BaseExcelUtil
  {
    private Workbook m_Wb = null;

    ///
    /// 生成Excel
    ///
    /// 模板Excel的路径+文件名
    /// Excel文件的字节对象
    public byte[] CreateExcel(string url)
    {
      FileStream fs = null;
      try
      {
        //读取模板Excel文件的中内容
        fs = new FileStream(url, FileMode.Open, FileAccess.Read, FileShare.Read);

        m_Wb = new Workbook();

        m_Wb.Open(fs);

        setValue(m_Wb);

        //转换为字节对象并返回
        return m_Wb.SaveToStream().ToArray();

      }
      catch (Exception ex)
      {
        throw ex;
      }
      finally
      {
        fs.Close();
      }
    }

    ///
    /// 设定Excel中的数据
    /// 数据源为datable类型
    ///
    /// 工作簿
    public virtual void setValue(Workbook wb)
    {
      throw new Exception("The method or operation is not implemented.");
    }

    ///
    /// 读取Excel
    ///
    /// Excel的路径+文件名
    /// Excel文件的字节对象
    public DataTable GetExcel(string url)
    {
      FileStream fs = null;
      try
      {
        //读取Excel文件的中内容
        fs = new FileStream(url, FileMode.Open, FileAccess.Read, FileShare.Read);

        m_Wb = new Workbook();

        m_Wb.Open(fs);

        //设定Excel中的数据
       return  getValue(m_Wb);

      }
      finally
      {
        fs.Close();
      }
    }

    ///
    /// 取得Excel中的数据
    ///
    /// 工作簿
    public virtual DataTable getValue(Workbook wb)
    {
      throw new Exception("The method or operation is not implemented.");
    }
    ///
    /// 设置字符串值
    ///
    ///
    ///
    public void putValue(Cell c, object value)
    {
      try
      {
        if (value == null || object.Equals(value, DBNull.Value) || value.ToString().Trim().Length == 0)
        {

        }
        else
        {
          c.PutValue(value.ToString());
        }
      }
      catch (Exception)
      {
        c.PutValue("--");
      }
    }
    ///
    /// 设置数值值
    ///
    ///
    ///
    public void putValueDouble(Cell c, object value)
    {
      try
      {
        if (value == null || object.Equals(value, DBNull.Value) || value.ToString().Trim().Length == 0)
        {

        }
        else
        {
          c.PutValue(Decimal.Parse(value.ToString()));
        }
      }
      catch (Exception)
      {
        c.PutValue(value.ToString());
      }
    }
    ///
    /// 设置日期值
    ///
    ///
    ///
    public void putDateValue(Cell c, object value)
    {
      try
      {
        if (value == null || object.Equals(value, DBNull.Value) || value.ToString().Trim().Length == 0)
        {

        }
        else
        {
          c.PutValue(DateTime.Parse(value.ToString()));
        }
      }
      catch (Exception)
      {
        c.PutValue(value.ToString());
      }
    }

  }

}

////实现基类

using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
using Aspose.Cells;
namespace Lzd.Mvc.EasyUi.Common.ExcelUtil
{
  ///
  /// Excel帮助类
  ///
  public class ExcelUtil :BaseExcelUtil
  {
    private DataTable dt;
    private string title;

    public ExcelUtil() {

    }

    ///
    /// 从第几行开始读取
    ///
    public int FirstRow { get; set; }
    ///
    /// 从第几列开始读取
    ///
    public int FirstColumns { get; set; }

    ///
    /// excel标题
    ///
    public string Title
    {
      get { return title; }
      set { title = value; }
    }
    private string fileName;

    ///
    /// 文件名
    ///
    public string FileName
    {
      get { return fileName; }
      set { fileName = value; }
    }

    public DataTable Dt
    {
      get { return dt; }
      set { dt = value; }
    }

    public bool Flag
    {
      set;
      get;
    }
   ///
   ///
   ///导出设定值
    public override void setValue(Workbook wb)
    {

      int index = 0;
      Worksheet ws = null;
      int rcount = dt.Rows.Count, columns = dt.Columns.Count;
      if (dt != null && dt.Rows.Count > 0)
      {
        index = wb.Worksheets.AddCopy(0);
        ws = wb.Worksheets[index];
        ws.Name = FileName.Replace(".xls", "");

        try
        {
          putValue(ws.Cells[0, 0], this.title);
          int i = 1;

          for (int j = 0; j < columns; j++)
          {

            putValue(ws.Cells[1, j], dt.Columns[j].ColumnName);
          }

          for (int j = 0; j < rcount; j++)
          {
            i++;
            for (int h = 0; h < columns; h++)
            {

              putValue(ws.Cells[i, h], dt.Rows[j][h].ToString());
            }

          }

          wb.Worksheets.RemoveAt(0);
        }
        catch (Exception ex)
        {
          throw ex;
        }
      }
    }

    ///
    /// 导入excel
    ///
    /// 读取的文件名
    /// 从第几行开始读取
    /// 从第几列开始读取
    ///
    /// 

    public override DataTable getValue(Workbook wb)
    {

      Worksheet sheet = wb.Worksheets[0];
      Cells cells = sheet.Cells;

      return cells.ExportDataTableAsString(FirstRow, FirstColumns, cells.MaxDataRow + 1, cells.MaxDataColumn + 1, true);
    }

  }

}

/////导出调用方法

public ActionResult ToExcel() {
      List list = new List();
      for (int i = 0; i < 100; i++)
      {
        UserInfo info = new UserInfo();
        info.Age = i.ToString();
        info.ID = i;
        info.Name = "姓名" + i;
        list.Add(info);
      }
      ///将list类型转换为datatable
      DataTable dt= DataTableHelper.IListToDataTable(list);
      //实例化帮助类
      ExcelUtil exc = new ExcelUtil();
      exc.Dt = dt;
      exc.FileName = "导出测试.xls";
      exc.Title = "导出测试";
      //需要写入的模板
      string url = Server.MapPath("/Content/Down/template.xls");
      byte[] data = exc.CreateExcel(url);
      //浏览器下载文件
      Response.AppendHeader("Content-Disposition", "attachment; filename=" + exc.FileName);//HttpUtility.UrlEncode(r.FileName, Encoding.UTF8));
      Response.ContentType = "application/ms-excel";
      Response.AddHeader("Content-Length", data.Length.ToString());
      Response.ContentEncoding = System.Text.Encoding.GetEncoding("UTF-8");
      Response.BinaryWrite(data);
      System.Web.HttpContext.Current.ApplicationInstance.CompleteRequest();
      return Content("ss");
    }

///导入调用方法

public ActionResult ImportExcel()
    {
      string url = Server.MapPath("/Content/Down/Import.xls");
      ExcelUtil exc = new ExcelUtil();
      exc.FirstRow = 1;
      exc.FirstColumns = 0;
       DataTable dt= exc.GetExcel(url);

      return Content("ss");
    }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Aspose.Cells组件导出excel文件

    本文实例为大家分享了Aspose.Cells导出excel文件的方法,供大家参考,具体内容如下 /// <summary> /// 导出数据到本地 /// </summary> /// <param name="dt">要导出的数据</param> /// <param name="tableName">导出名称</param> /// <param name="tableTit

  • C#使用Aspose.Cells创建和读取Excel文件

    使用Aspose.Cells创建和读取Excel文件,供大家参考,具体内容如下 1. 创建Excel Aspose.Cells.License li = new Aspose.Cells.License(); li.SetLicense("Aspose.Cells.lic"); Aspose.Cells.Workbook wk = new Aspose.Cells.Workbook(); Worksheet ws = wk.Worksheets[0]; for (int i = 0;

  • 利用Aspose.Cells实现万能导出功能

    最近做了个项目,客户对导出excel功能情有独钟,几乎要求每一个列表数据都支持导出excel功能,为了避免代码重复,万能粉嫩的小码农开发了万能导出QAQ. 导出Excel无非就是取出数据,然后利用Aspose.Cells插件填充到Excel文件中,DataTable类型的数据是最适合填充Excel不过了.唯一的问题就是DataTable数据的列头一般是英文,突然就想出了利用SQL Server每一列的说明来替换掉英文列头的方法,我太TM机智了. /// <summary> /// 导出 ///

  • C#使用Aspose.Cells导出excel

    C# winform导出excel可以使用 Microsoft.Office.Interop.Excel.dll或者Aspose.Cells.dll以及其他方法.Microsoft.Office.Interop.Excel.dll导出速度慢,不适用于数据量大情况.Aspose.Cells.dll到处速度很快.由于Aspose.Cells.dll本身收费,所以需要加载破解证书. Aspose.Cells简介:Aspose.Cells是一款功能强大的Excel文档处理和转换控件,开发人员和客户电脑无

  • Aspose.Cells 读取受保护有密码的Excel文件

    最近遇到一个需求,要能够读取受密码保护的Excel内容,之前都是直接读取Excel中的数据,不需要做任何其他的处理. 当Excel双击的时候,需要输入密码,在使用Aspose.Cells 组件读取的时候就会报错 Workbook book = new Workbook(fullFilename, new LoadOptions() { Password="111111" }); Worksheet sheet = book.Worksheets[0]; Cells cells = sh

  • C#使用Aspose.Cells控件读取Excel

    Aspose是一个很强大的控件,可以用来操作word,excel,ppt等文件,用这个控件来导入.导出数据非常方便.其中Aspose.Cells就是用来操作Excel的,功能有很多.我所用的是最基本的功能,读取Excel的数据并导入到Dataset或数据库中.读取Excel表格数据的代码如下: 首先要引入命名空间:using Aspose.Cells; 复制代码 代码如下: Workbook workbook = new Workbook(); workbook.Open("C:\\test.x

  • 使用Aspose.Cells组件生成Excel文件实例

    生成带表头的Excel文件,格式如下显示. 当然更复杂的一些也可以通过 合并单元格的方法 public void Merge(int firstRow, int firstColumn, int totalRows, int totalColumns)来实现. 实现方式: 1. 首先,需要添加对"Aspose.Cells.dll"的引用. 2. 实现代码如下: 复制代码 代码如下: //新建工作簿             Workbook workbook = new Workbook

  • 使用Aspose.Cells实现导入导出

    本文实例为大家分享了Aspose.Cells实现导入导出的具体代码,供大家参考,具体内容如下 这是自己整理的导入导出类,里面有注释. using System; using System.Collections.Generic; using System.Data; using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; using Aspose.Cells; namespace L

  • C#语言MVC框架Aspose.Cells控件导出Excel表数据

    本文实例为大家分享了Aspose.Cells控件导出Excel表数据的具体代码,供大家参考,具体内容如下 控件bin文件下载地址 @{ ViewBag.Title = "xx"; } <script type="text/javascript" language="javascript"> function getparam() { var param = {}; param.sear = $("#sear").t

  • C# 使用Aspose.Cells 导出Excel的步骤及问题记录

    今天在工作中碰到同事用了一种新型的方式导入excel,在此做个学习记录. Aspose.Cells简介:Aspose.Cells是一款功能强大的Excel文档处理和转换控件,开发人员和客户电脑无需安装Microsoft Excel也能在应用程序中实现类似Excel的强大数据管理功能,支持所有Excel格式类型的操作,在没有Microsoft Excel的环境下,用户也可为其应用程序嵌入类似Excel的强大数据管理功能. 插件:Aspose.Cells 第一步:准备好导出的模板,例子: C#代码:

  • 利用Aspose.Cells和Excel模板导出统计数据

    在项目中要进行导出Excel报表给客户,里面有统计,就心思用Aspose.Cells 配合实体类数据直接导出.结果呢比较麻烦.然后就检索找到利用Excel模板配合实体类数据导出. 总的来说一般的报表生成,基本上是基于以下几种方式:一种是基于微软Excel内置的引擎来实现:一种是构造HTML格式的Excle报表:一种是基于控件的方式来处理,基于控件有很多种方式,个人认为比较有名的是Aspose.Cell和NPOI,下面用到的是Aspose.Cell 效果图: Excel模板及相关变量 报表1模板如

  • ASP.NET Core 导入导出Excel xlsx 文件实例

    ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Linux和Mac. EPPlus.Core 是基于EPPlus 更改而来,在Linux 下需要安装libgdiplus . EPPlus:http://epplus.codeplex.com/ EPPlus.Core:https://github.com/VahidN/EPPlus.Core 下面在A

  • C#导入导出Excel数据的两种方法

    本文为大家分享了C#导入导出Excel数据的具体代码,供大家参考,具体内容如下 注:对于实体类对象最好新建一个并且继承原有实体类,这样可以将类型进行修改: 方法一:此种方法是用EPPLUS中的FileInfo流进行读取的(是不是流我还真不太了解,若有懂得请留言,非常感谢了) using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tas

随机推荐