使用Aspose.Cells实现导入导出
 更新时间:2018年12月13日 14:07:05   作者:HI阡陌  

这篇文章主要为大家详细介绍了如何使用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”);
}

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

您可能感兴趣的文章:C#使用Aspose.Cells导出excel利用Aspose.Cells实现万能导出功能C#使用Aspose.Cells创建和读取Excel文件Aspose.Cells 读取受保护有密码的Excel文件C#使用Aspose.Cells控件读取Excel使用Aspose.Cells组件生成Excel文件实例Aspose.Cells组件导出excel文件

Aspose.Cells
导入
导出

相关文章
如何合并多个 .NET 程序集这篇文章主要介绍了如何合并多个 .NET 程序集的方法,大家可能都听说过项 ILMerge, SmartAssembly, 等这样的工具.但是我想如果我们就能通过在编译时将所有这些源代码文件导入一个项目,来获得这些东西的一个完美组合.下面我们就来仔细探讨下。 2015-03-03
ASP.NET MVC5网站开发我的咨询列表及添加咨询(十二)这篇文章主要介绍了ASP.NET MVC5网站开发我的咨询列表及添加咨询 2015-09-09
asp.net动态加载自定义控件的方法这篇文章主要介绍了asp.net动态加载自定义控件的方法,涉及asp.net动态加载控件的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下 2015-04-04
asp.net(c#)网页跳转七种方法小结在asp.net下,经常需要页面的跳转,下面是具体的几种方法。跳转页面是大部编辑语言中都会有的,正面我们来分别介绍一下关于.net中response.redirect sever.execute server.transfer 三种页面跳转的方法 2009-11-11
ASP.NET MVC5网站开发之添加\\删除\\重置密码\\修改密码\\列表浏览管这篇文章主要为大家详细介绍了ASP.NET MVC5网站开发之添加\\删除\\重置密码\\修改密码\\列表浏览,感兴趣的小伙伴们可以参考一下 2016-08-08
.NET中如何将文本文件的内容存储到DataSet大家在项目中比较多的会对文件进行操作,例如文件的上传下载,文件的压缩和解压等IO操作。而在.NET项目中较多的会使用DataSet,DataTable进行数据的缓存。每一个DataSet都是一个或多个DataTable对象的集合,本文主要介绍的是如何将文本文件的内容存储到DataSet里去。 2016-12-12
解读ASP.NET密码强度验证代码实例分享这篇文章介绍了ASP.NET密码强度验证代码实例,有需要的朋友可以参考一下 2013-10-10
.Net Core和jexus配置HTTPS服务方法下面小编就为大家分享一篇.Net Core和jexus配置HTTPS服务方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧 2018-02-02
asp.net(c#)判断远程图片是否存在不错的应用,大家可以拓展到,判断远程文件是否存在等功能 2008-09-09
asp.net 设置GridView的选中行当点某行时,直接选中,然后移动方向键则切换不同的选中行; 如果直接按方向键,则从第一行开始标识 2009-04-04

最新评论

声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。