设为首页 加入收藏

TOP

基于.net EF6 MVC5+WEB Api 的Web系统框架总结(4)-Excel文件读、写操作(一)
2019-09-23 11:13:00 】 浏览:83
Tags:基于 .net EF6 MVC5 WEB Api Web 系统 框架 总结 -Excel 文件 操作

  Excel文件读、写可以使用Office自带的库(Microsoft.Office.Interop.Excel),前提是本机须安装office才能运行,且不同的office版本之间可能会有兼容问题。
还可以使用NPOI,在不安装office的时候也是可以读写的,速度很快。当然,还有支持Excel2007以上版本的OpenXml。以及其他一些开源项目,由于本人不太熟悉,在此不做过多介绍。
  为了解决烦人Office版本兼容问题,本项目-ShiQuan.Offices 决定采用基于NPOI,进行Excel文件读、写操作。
  本项目目前实现内容包括:
  1、直接根据DataTable,生成Excel文件内容。
  2、根据列表设置和DataTable,生成Excel文件内容。
  3、根据Excel模板,使用模板设置,生成Excel文件内容。
  4、读取Excel内容,返回DataTable。

  本项目基于LGPL3.0开源,供大家参考、使用,欢迎提供宝贵意见!
  项目源码:https://gitee.com/ShiQuanSoft/ShiQuan.Offices

 

  下面介绍分享如何使用该项目-ShiQuan.Offices。
  首先,创建ConsoleApp测试项目,添加程序包安装:

     

    1、先我们试下,普通的DataTable生成Excel文件是怎样的?

try
            {
                //取出数据源
                DataTable dtData = new DataTable();
                dtData.Columns.Add("account");
                dtData.Columns.Add("realname");
                dtData.Columns.Add("birthday");
                dtData.Columns.Add("description");
                dtData.Columns.Add("remark");

                DataRow dr = dtData.NewRow();
                dr["account"] = "账户";
                dr["realname"] = "姓名";
                dr["birthday"] = "2000-05-25";
                dr["description"] = "说明";
                dr["remark"] = "说明";/*多余字段,不会数据导出*/
                dtData.Rows.Add(dr);
                Console.WriteLine("生成2007以上版本Excel...");
                NPOIHelper.SaveToExcel(dtData, "XSSFWorkbook.xlsx");
                Console.WriteLine("生成2003版本Excel...");
                NPOIHelper.SaveToExcel(dtData, "HSSFWorkbook.xls");
            }
            catch (Exception ex)
            {
                Console.WriteLine("导出异常:" + ex.Message);
            }

  运行效果:

     

  2、一般从系统中导出Excel,我们都将采用中文标题,设置相应的数据列格式,对齐方式等信息?

 

try
            {
                //取出数据源
                DataTable dtData = new DataTable();
                dtData.Columns.Add("account");
                dtData.Columns.Add("realname");
                dtData.Columns.Add("gender");
                dtData.Columns.Add("birthday");
                dtData.Columns.Add("enabled");
                dtData.Columns.Add("price");
                dtData.Columns.Add("percent");
                dtData.Columns.Add("money");
                dtData.Columns.Add("remark");

                DataRow dr = dtData.NewRow();
                dr["account"] = "账户";
                dr["realname"] = "姓名";
                dr["gender"] = "0";/*0:女*/
                dr["birthday"] = "2000-05-25";
                dr["price"] = "10.5656";
                dr["percent"] = "0.56";
                dr["money"] = "1000.56";
                dr["enabled"] = "1";/*是否启用:1:是*/
                dr["remark"] = "说明";/*多余字段,不会数据导出*/
                dtData.Rows.Add(dr);
                /*设置导出格式*/
                ColumnCollection colModel = new ColumnCollection();
                colModel.Add("account", "账户");
                colModel.Add("realname", "姓名");
                colModel.Add("birthday", "出生日期", typeof(DateTime), "yyyy年MM月dd日");
                colModel.Add("price", "保留两位",typeof(double), "#0.00");
                colModel.Add("percent", "百分比", typeof(double), "0.00%");
                colModel.Add(new ColumnModel() { Name = "money", Desc = "货币格式", Type = typeof(double), Format = "¥#,##0", TextAlign = Column
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇.NET Core 代码安装服务启动 下一篇论序列化与反序列化

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目