1. 导出exl表格,创建表格导出到客户端

  public static MemoryStream Export_Table<T>(List<T> datalist)
{
MemoryStream ms = new MemoryStream();
var members = typeof(T).GetProperties();
var workbook = new NPOI.HSSF.UserModel.HSSFWorkbook();
NPOI.SS.UserModel.ISheet sheet = workbook.CreateSheet();
NPOI.SS.UserModel.IRow headerRow = sheet.CreateRow();
int order = ;
foreach (var meber in members)//初始化标题
{
string titlevalue = "";
var name = meber.GetCustomAttributes(typeof(TableAttribulate), false);
if (name.Length == )
continue;
var pro = name[] as TableAttribulate;
if (pro == null)
continue;
titlevalue = pro.CName;
var cell = headerRow.CreateCell(order);
cell.SetCellValue(titlevalue);
if(pro.Weight==)
sheet.AutoSizeColumn(order,true);
else
{
sheet.SetColumnWidth(order,pro.Weight);
}
cell.CellStyle = GetStyle(workbook);
cell.CellStyle.Alignment = pro.HorizontalAlignment;
var cellfont = workbook.CreateFont();
cellfont.Boldweight = (short)NPOI.SS.UserModel.FontBoldWeight.Bold;
cell.CellStyle.SetFont(cellfont);
order++;
} int rowIndex = ;
foreach (var row in datalist)
{
NPOI.SS.UserModel.IRow dataRow = sheet.CreateRow(rowIndex);
int colIndex = ;
var cellindex = dataRow.CreateCell(colIndex);
cellindex.SetCellValue(rowIndex);
cellindex.CellStyle = GetStyle(workbook);
var cellfont = workbook.CreateFont();
cellfont.Boldweight = (short)NPOI.SS.UserModel.FontBoldWeight.Normal;
cellfont.Color = NPOI.HSSF.Util.HSSFColor.LightBlue.Index;
cellindex.CellStyle.SetFont(cellfont);
colIndex++;
foreach (var meber in members)
{
var name = meber.GetCustomAttributes(typeof(TableAttribulate), false);
if (name.Length == )
continue;
var pro = name[] as TableAttribulate;
if (pro == null)
continue;
if (pro.Weight == )
sheet.AutoSizeColumn(colIndex, true);
var cell = dataRow.CreateCell(colIndex);
var mebervalue = meber.GetValue(row);
cell.SetCellValue(mebervalue == null ? "" : mebervalue.ToString());
cell.CellStyle = GetStyle(workbook);
cell.CellStyle.Alignment = pro.HorizontalAlignment;
colIndex++;
}
rowIndex++;
}
workbook.Write(ms);
ms.Seek(, SeekOrigin.Begin);
return ms;//
}

2.代码总的特性

public class TableAttribulate:Attribute
{
public TableAttribulate(string name, int weight = , NPOI.SS.UserModel.HorizontalAlignment hoalign = NPOI.SS.UserModel.HorizontalAlignment.Center)
{
CName = name;
Weight = weight;
HorizontalAlignment = hoalign;
}
public string CName { get; set; } public int Weight { get; set; } public NPOI.SS.UserModel.HorizontalAlignment HorizontalAlignment { get; set; }//对齐方式 }

3.函数样式

        public static NPOI.SS.UserModel.ICellStyle GetStyle(NPOI.HSSF.UserModel.HSSFWorkbook workbook)
{
var cs = workbook.CreateCellStyle();
cs.DataFormat = NPOI.HSSF.UserModel.HSSFDataFormat.GetBuiltinFormat("@");
cs.BorderBottom = NPOI.SS.UserModel.BorderStyle.Thin;
cs.BorderLeft = NPOI.SS.UserModel.BorderStyle.Thin;
cs.BorderRight = NPOI.SS.UserModel.BorderStyle.Thin;
cs.BorderTop = NPOI.SS.UserModel.BorderStyle.Thin;
cs.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;
cs.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center; var cellfont = workbook.CreateFont();
cellfont.Boldweight = (short)NPOI.SS.UserModel.FontBoldWeight.Normal; cs.SetFont(cellfont);
return cs;
}

老版的:

       public static NPOI.SS.UserModel.ICellStyle GetDefaultStyle(XSSFWorkbook workbook)
{
var cs = workbook.CreateCellStyle();
cs.DataFormat = NPOI.HSSF.UserModel.HSSFDataFormat.GetBuiltinFormat("@");
cs.BorderBottom = NPOI.SS.UserModel.BorderStyle.Thin;
cs.BorderLeft = NPOI.SS.UserModel.BorderStyle.Thin;
cs.BorderRight = NPOI.SS.UserModel.BorderStyle.Thin;
cs.BorderTop = NPOI.SS.UserModel.BorderStyle.Thin;
cs.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;
cs.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center;
var cellfont = workbook.CreateFont();
cellfont.Boldweight = (short)NPOI.SS.UserModel.FontBoldWeight.Normal;
cs.SetFont(cellfont);
return cs;
}

4.js调用实例

        function func_queryExportExl() {
var url = '@Url.Action("ExportExcel", "ResidentsSigned");
window.location.href = url;
}

5.后端调用

List<TableExel> query = dbContext.Database.SqlQuery<TableExel>(sql).ToList();
var ms = CPSYS.Web.Common.FileOption.Export_Table<TableExel>(query);
return File(ms, "application/vnd.ms-excel", "text.xls");

6.合并单元格后的边框格式问题

  public void SetTyleThin(NPOI.HSSF.UserModel.HSSFWorkbook workbook,NPOI.SS.UserModel.ISheet sheet,int lastrow)
{
NPOI.SS.Util.CellRangeAddress region = new NPOI.SS.Util.CellRangeAddress(, lastrow, , );
((NPOI.HSSF.UserModel.HSSFSheet)sheet).SetEnclosedBorderOfRegion(region, NPOI.SS.UserModel.BorderStyle.Thin, NPOI.HSSF.Util.HSSFColor.Black.Index);
}

7.读入模板

            HSSFWorkbook workbook = null;
var path = AppDomain.CurrentDomain.BaseDirectory + "/ExcelTemplate/重点孕妇登记随访本.xls";
FileStream filest = new FileStream(path, FileMode.Open, FileAccess.Read); workbook = new HSSFWorkbook(filest);
filest.Close(); NPOI.SS.UserModel.ISheet sheet = workbook.GetSheet("重点孕妇登记随访本");

NPOI _导出exl(简单应用)的更多相关文章

  1. NET使用NPOI组件导出Excel-入门示例及通用方法

    一.Excel导入及导出问题产生:   从接触.net到现在一直在维护一个DataTable导出到Excel的类,时不时还会维护一个导入类.以下是时不时就会出现的问题:   导出问题:   如果是as ...

  2. .Net core NPOI导入导出Excel

    最近在想.net core NPOI 导入导出Excel,一开始感觉挺简单的,后来真的遇到很多坑.所以还是写一篇博客让其他人少走一些弯路,也方便忘记了再重温一遍.好了,多的不说,直接开始吧. 在.Ne ...

  3. c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出

    c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...

  4. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  5. NPOI导入导出Excel

    .net mvc利用NPOI导入导出excel 注意:如何导出的提交方式ajax导出是失效的! 解决方案是:js处理l两个表单的提交  代码:  第一步. 在页面里面加入2个隐藏的iframe, 如下 ...

  6. Flutter实战视频-移动电商-05.Dio基础_引入和简单的Get请求

    05.Dio基础_引入和简单的Get请求 博客地址: https://jspang.com/post/FlutterShop.html#toc-4c7 第三方的http请求库叫做Dio https:/ ...

  7. 简单回顾NPOI导入导出excel文件

    当前环境.net4.0 去官方下下载:  NOPI官网 关于NOPI的详细,这里就不再介绍. 在项目中,我们只需引入  NPOI.dll  就可以了. 接下来..................... ...

  8. C# 使用NPOI 实现Excel的简单导入导出

    private void btnImport_Click(object sender, EventArgs e) { DataSet ds = new DataSet(); DataTable dt ...

  9. NPOI 给导出Excel添加简单样式

    需求分析:如下图为我之前导出的Excel数据,没有一点样式,标题行不明显,各个列的数据紧凑,查看数据时得手动拉宽每列,故这次要针对以上问题对它进行优化 结果展示: 代码: /// <summar ...

随机推荐

  1. 如何在vue-cli中使用vuex(配置成功

    前言 众所周知,vuex 是一个专为 vue.js 应用程序开发的状态管理模式,在构建一个中大型单页应用中使用vuex可以帮助我们更好地在组件外部管理状态.而vue-cli是vue的官方脚手架,它能帮 ...

  2. Newtonsoft--自定义格式化日期

    public string ToJson(object obj, string timeFormat) { try { IsoDateTimeConverter timeConverter = new ...

  3. 【spring boot】SpringBoot初学(7)– 多数据源及其事务

    前言 github: https://github.com/vergilyn/SpringBootDemo 代码位置: 参考: Spring Boot Reference Guide , §77.2 ...

  4. 最新Idea激活码,持续更新

    更新时间2020-01-10,亲测可用. 激活码老是失效,太麻烦,选择永久激活的方法,此方法,只针对Idea2019.2.1以及之前版本的. 附上链接: https://www.cnblogs.com ...

  5. kali2019.4试用记录

    问题一:中文乱码 https://blog.csdn.net/dust_hk/article/details/103299136 参考以上博文即可解决: 1.设置locales. dpkg-recon ...

  6. gulp常用插件之gulp-plumber使用

    更多gulp常用插件使用请访问:gulp常用插件汇总 gulp-plumber这是一款防止因gulp插件的错误而导致管道中断,plumber可以阻止 gulp 插件发生错误导致进程退出并输出错误日志. ...

  7. xctf-ics-07

    首先管理页面进入到云平台项目管理中心 发现下面可以查看源码,点击view-source: 这个直接就绕过去了 看第二个 第二个需要满足$_SESSION['admin']==true才行,因此看看第三 ...

  8. 数据库中的sql语句总结

    初识SQL   1. 什么是SQL:结构化查询语言(Structured Query Language). 2. SQL的作用:客户端使用SQL来操作服务器.   > 启动mysql.exe,连 ...

  9. 技术之心 | 云信和TA们携手打响防疫战

      1月27日,教育部发布<关于2020年春季学期延期开学的通知>,各地高等院校.中小学.幼儿园纷纷推迟开学.疫情当前,学生们的鼠年寒假变得无比漫长. 网易云信众多教育客户以行动践行教育的 ...

  10. 永久破解pycharm,golang,IDEA开发工具

    1.去官网下载需要破解的IEDA 此处略去......... 2.需要破解的可以添加我微信获取破解jar包(百度网盘链接怕失效) 867716617 3.把jar包放在需要破解的IDEA安装目录中的l ...