说明

本教程主要说明如果使用Magicodes.IE.Excel完成教材订购表的Excel模板导出。

要点

  • 本教程使用Magicodes.IE.Excel来完成Excel模板导出
  • 需要通过创建Dto来完成导出
  • 需要按要求准备Excel模板

主要步骤

1.安装包Magicodes.IE.Excel

在本篇教程中,我们仅演示使用Excel来完成学生数据的导入。我们需要在已准备好的工程中安装以下包,参考命令如下所示:

Install-Package Magicodes.IE.Excel

2.准备模板

Magicodes.IE.Excel模板导出支持单元格渲染和表格渲染:

  • 单元格渲染

    语法:

    {{Company}}             (教学单位名称)2020年春季教材订购明细

    注意:

    • 双大括号是必须的
    • 暂不支持表达式等
    • 支持子对象属性
    • 大小写敏感
  • 表格渲染

表格渲染的格式如上所述:

  • 渲染语法以“Table>>BookInfos|”为开始,其中“BookInfos”为列表属性

  • “RowNo”、“No”等均为列表字段

  • 必须以“|>>Table”结尾

  • 暂不支持一行多个Table(即将支持,具体请查看日志)

根据以上语法,我们可以编写模板如下所示:

3.创建导出Dto

主要代码如下所示:

  • 教材订购信息Dto

    /// <summary>/// 教材订购信息/// </summary>public class TextbookOrderInfo{/// <summary>/// 公司名称/// </summary>public string Company { get; }/// <summary>/// 地址/// </summary>public string Address { get; }/// <summary>/// 联系人/// </summary>public string Contact { get; }/// <summary>/// 电话/// </summary>public string Tel { get; }/// <summary>/// 制表人/// </summary>public string Watchmaker { get; }/// <summary>/// 时间/// </summary>public string Time { get; }/// <summary>/// 教材信息列表/// </summary>public List<BookInfo> BookInfos { get; }public TextbookOrderInfo(string company, string address, string contact, string tel, string watchmaker, string time, List<BookInfo> bookInfo){Company = company;Address = address;Contact = contact;Tel = tel;Watchmaker = watchmaker;Time = time;BookInfos = bookInfo;}}

    如上述代码所示,定义的结构基本上和模板一致。其中属性BookInfos对应列表,具体定义如下所示。

  • 教材信息Dto:

    /// <summary>/// 教材信息/// </summary>public class BookInfo{/// <summary>/// 行号/// </summary>public int RowNo { get; }/// <summary>/// 书号/// </summary>public string No { get; }/// <summary>/// 书名/// </summary>public string Name { get; }/// <summary>/// 主编/// </summary>public string EditorInChief { get; }/// <summary>/// 出版社/// </summary>public string PublishingHouse { get; }/// <summary>/// 定价/// </summary>public string Price { get; }/// <summary>/// 采购数量/// </summary>public int PurchaseQuantity { get; }/// <summary>/// 备注/// </summary>public string Remark { get; }public BookInfo(int rowNo, string no, string name, string editorInChief, string publishingHouse, string price, int purchaseQuantity, string remark){RowNo = rowNo;No = no;Name = name;EditorInChief = editorInChief;PublishingHouse = publishingHouse;Price = price;PurchaseQuantity = purchaseQuantity;Remark = remark;}}

4.导出

接下来直接调用Magicodes.IE.Excel封装的模板导出方法,该方法实现自接口IExportFileByTemplate:

 /// <summary>/// 根据模板导出文件/// </summary>public interface IExportFileByTemplate{/// <summary>///     根据模板导出/// </summary>/// <typeparam name="T"></typeparam>/// <param name="fileName"></param>/// <param name="data"></param>/// <param name="template">HTML模板或模板路径</param>/// <returns></returns>Task<ExportFileInfo> ExportByTemplate<T>(string fileName, T data,string template) where T : class;}

通过以上方法中的ExportByTemplate,我们就可以完成Excel模板导出。具体使用可以参考以下单元测试:

[Fact(DisplayName = "Excel模板导出教材订购明细样表")]
public async Task ExportByTemplate_Test()
{//模板路径var tplPath = Path.Combine(Directory.GetCurrentDirectory(), "TestFiles", "ExportTemplates","2020年春季教材订购明细样表.xlsx");//创建Excel导出对象IExportFileByTemplate exporter = new ExcelExporter();//导出路径var filePath = Path.Combine(Directory.GetCurrentDirectory(), nameof(ExportByTemplate_Test) + ".xlsx");if (File.Exists(filePath)) File.Delete(filePath);//根据模板导出await exporter.ExportByTemplate(filePath,new TextbookOrderInfo("湖南心莱信息科技有限公司", "湖南长沙岳麓区", "雪雁", "1367197xxxx", "雪雁", DateTime.Now.ToLongDateString(),new List<BookInfo>(){new BookInfo(1, "0000000001", "《XX从入门到放弃》", "张三", "机械工业出版社", "3.14", 100, "备注"),new BookInfo(2, "0000000002", "《XX从入门到放弃》", "张三", "机械工业出版社", "3.14", 100, "备注"),new BookInfo(3, "0000000003", "《XX从入门到放弃》", "张三", "机械工业出版社", "3.14", 100, "备注")}),tplPath);
}

结果如下图所示:

最后

整个Excel模板导出教程就此结束了,由于仓促完成,还有许多地方可以改善并优化。

相关库会一直更新,在功能体验上有可能会和本文教程有细微的出入,请以相关具体代码、版本日志、单元测试示例为准。

编程交流群<85318032>,产品交流群<897857351>。

Magicodes.IE之Excel模板导出教材订购表相关推荐

  1. Excel模板导出之导出教材订购表

    说明 本教程主要说明如果使用Magicodes.IE.Excel完成教材订购表的Excel模板导出. 要点 本教程使用Magicodes.IE.Excel来完成Excel模板导出 需要通过创建Dto来 ...

  2. Excel模板导出之动态导出

    说明 目前Magicodes.IE已支持Excel模板导出时使用JObject.Dictionary和ExpandoObject来进行动态导出,具体使用请看本篇教程. 本功能的想法.部分实现初步源于a ...

  3. .Net NPOI 根据excel模板导出excel、直接生成excel

    一.根据Excel模板导出excel 1.导入NPOI.dll  2.DAL中添加类ExportExcel.cs using NPOI.SS.UserModel; using System; usin ...

  4. 6、jeecg 笔记之 自定义excel 模板导出(一)

    6.jeecg 笔记之 自定义excel 模板导出(一) 1.前言 jeecg 中已经自带 excel 的导出导出功能,其所使用的是 easypoi,尽管所导出的 excel 能满足大部分需求, 但总 ...

  5. 基于Excel模板导出——ExcelTemplate

    什么是ExcelTemplate ExcelTemplate项目是一个基于Excel模板,依靠配置文件描述导出过程的Excel导出工具. 它提供了大量适用于各种场景的常用配置(导出规则),同时提供一些 ...

  6. 使用EasyPoi利用excel模板导出excel表格下载

    前言:使用excel模板导出excel的好处在于可以事先在模板上定义颜色.格式等,适用于模板设计得比较灵活复杂的场景 一.添加jar包 <dependency><groupId> ...

  7. springboot+poi开发excel导出 加载Excel模板导出 Excel批量导出详解

    提到Excel导出功能,可能很多人都使用springmvc框架做过,笔者今天要给大家分享的是基于springBoot开发Excel复杂模板导出功能(所谓复杂模板指在模板里的特定表头里有不同的单元格合并 ...

  8. php excel模板导出、openoffice excel转pdf、多文件压缩下载

    最近两周都在弄关于excel模板导出.excel转pdf.多文件压缩下载.弄得头都大了,接下来说说实现的方法吧. 我用的是laravel5.1的框架,读取模板生成excel,并且插入图片,直接上代码 ...

  9. C#中通过Excel模板导出数据

    一.实现效果 1.1.编写特定格式的Excel模板 1.2.调用Excel模板导出数据 二.实现核心 #region 通过模板导出Excel文件/// <summary>/// 通过模板导 ...

最新文章

  1. 基于视频理解TSM和数据集20bn-jester-v1的27类手势识别
  2. C语言 (条件编译#ifdef、#ifndef) (#if 常量,#if 1,#if 0)的用法
  3. 如何在Windows 10上使用Microsoft Defender扫描文件或文件夹中的恶意软件
  4. akka_Akka的字数统计MapReduce
  5. vuex commit 传参数,传递多个参数
  6. python中input()与raw_input()的区别到底是啥?-----marsggbo原创作品为你解答
  7. HighCharts入门
  8. mysql blob图片_显示存储在mysql blob中的图像
  9. bs架构多用户访问_Spark架构
  10. 使用Requests+xpath实现简单的数据爬取
  11. IntelliLock
  12. Qt 信号与槽机制及实战案例
  13. linux的键盘命令用户登录,linux 基础命令
  14. 太极图php代码,如何实现太极图
  15. qt自定义控件-柱状刻度尺
  16. 设计模式 -- 访问者模式(Visitor)
  17. 《构建之法》学习总结2——软件工程需求分析
  18. verilog——74HC85四位数值比较器并扩展为16位数值比较器
  19. 计算机基础活页式教材模板,大学计算机基础WORD文章(排版前)
  20. 《Xmind 用好思维导图走上开挂人生》记录

热门文章

  1. 【原创】Android无线视频监控小车--前篇
  2. 几何原本(数学家的儿童玩具)
  3. 08年朗讯(青岛)笔试题
  4. c语言计算火车运行图调整暂停发售,列车运行图调整暂停发售是什么意思
  5. 万网php发不了邮件,万网等虚拟主机不能SMTP发信的解决方案
  6. 【若依(ruoyi)】使用 iconfont 增强图标
  7. Android 三国杀 百度账号,三国杀移动版多酷账号版本下载-三国杀移动版多酷版v3.9.2 安卓版-腾牛安卓网...
  8. 三国杀移动版显示服务器忙,三国杀移动版
  9. 今日头条信息流广告浅尝截止
  10. Ajax设置超时时长,jquery ajax超时设置