使用Aspose.Cells实现导入导出
更新时间:2021年9月22日 10:01 点击:2055
本文实例为大家分享了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"); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持猪先飞。
下一篇: WPF实现进度条实时更新效果
相关文章
js导出table数据到excel即导出为EXCEL文档的方法
复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta ht...2013-10-13详解在IDEA中将Echarts引入web两种方式(使用js文件和maven的依赖导入)
这篇文章主要介绍了在IDEA中将Echarts引入web两种方式(使用js文件和maven的依赖导入),本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11- C# 导出 Excel 的6种简单方法:数据表导出到 Excel,对象集合导出到 Excel,数据库导出到 Excel,微软网格控件导出到 Excel,数组导出到 Excel,CSV 导出到 Excel,你都会了吗?需要的朋友们下面随着小编来一起学习学习吧...2020-06-25
- 这篇文章主要给大家总结介绍了R语言导入导出数据的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-06
- 这篇文章主要为大家详细介绍了C#使用Aspose.Cells创建和读取Excel文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-06-25
- 本文介绍Aspose.Cells基础的用法,供大家参考。...2020-06-25
phpexcel导入xlsx文件报错xlsx is not recognised as an OLE file 怎么办
phpexcel是一款php读写excel的插件了,小编有一个这样的功能要来实现,但是在导入xlsx时发现xlsx is not recognised as an OLE file 了,但是导入xls是没有问题了,碰到这种...2016-11-25- 今天小编就为大家分享一篇关于C#数据导入到EXCEL的方法,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...2020-06-25
- 让C# Excel导入导出,支持不同版本的Office,感兴趣的小伙伴们可以参考一下...2020-06-25
- 这篇文章主要为大家详细介绍了java导出csv格式文件的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-12-31
- 这篇文章主要介绍了Go 自定义package包设置与导入操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-05-06
- 这篇文章主要介绍了Vue通过Blob对象实现导出Excel功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-08-01
- 这篇文章主要介绍了C#导出数据到excel如何提升性能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-07-13
- 这篇文章主要为大家详细介绍了C# Winform实现导入和导出Excel文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-06-25
- 下面我来给大家介绍在php中操作excel两个实例,一个是利用PHP-ExcelReader导入excel并输出,另一种是直接输入excel并导出,下面看实例。 借助PHP-ExcelReader这个开...2016-11-25
php利用ExcelFileParser把excel导入数据库
这是一款实用的php教程利用excelfileparser把excel导入数据库教程哦。 代码如下 复制代码 <!doctype html public "-//w3c//dtd xhtml 1.0 transi...2016-11-25- 这篇文章主要为大家详细介绍了利用Aspose.Cells和Excel模板导出复杂的统计数据,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-06-25
- 从sql导出到mysql的方法很多,现介绍一种无需编程,直接利用sql和mysql里的图形界面进行导入导出的简单方法。 前提是已经安装了sqlserver客户端和mysql的图形界...2016-11-25
- 下面小编就为大家带来一篇mysql导出查询结果到csv的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2017-04-26
基于BootStrap Metronic开发框架经验小结【七】数据的导入、导出及附件的查看处理
在很多系统模块里面,我们可能都需要进行一定的数据交换处理,这样可以很好的达到用户操作体验感,接下来通过本文给大家介绍基于BootStrap Metronic开发框架经验小结【七】数据的导入、导出及附件的查看处理相关知识,非常具有参考价值,感兴趣的朋友一起学习吧...2016-05-14