C#如何利用NPOI生成具有精确列宽行高的Excel文件
来源:互联网 发布:谁有千百鲁最新域名 编辑:程序博客网 时间:2024/05/22 13:54
前言
NPOI是操作Excel的神器,导出导入快如闪电,
但是SetColumnWidth函数个人感觉不会用,怎么弄都无法控制好,因为他是以字符数量去设置宽度,实际上Excel列宽还有个像素的概念,更搞不懂了
//附带SetColumnWidth的用法和注释
IWorkbook hssfworkbook = new HSSFWorkbook();ISheet sheet1 = hssfworkbook.CreateSheet("Sheet1"); sheet1.SetColumnWidth(1, 100 * 256);// 摘要: // Set the width (in units of 1/256th of a character width) The maximum column // width for an individual cell is 255 characters. This value represents the // number of characters that can be displayed in a cell that is formatted with // the standard font. // // 参数: // columnIndex: // the column to set (0-based) // // width: // the width in units of 1/256th of a character width
看着这注释我就觉得很蛋疼
遇到的问题
那么如果你需要生成固定格式的Excel,要有精确的列宽和行高,要用于打印等特殊需求,又如何解决呢
解决方案
哈哈,投机取巧之法,
建立一个已经设置好行高列宽的xls作为模板,在需要填充字符的地方随便填充一点字符(避免NPOI任务该单元格是NULL),设置好字体等内容,
利用NPOI打开这个xls文件,对对应的空格进行SetValue,然后保存文件,由于NPOI是对于文件流的操作而不是用Excel.exe去操作Excel,所以生成文件的效率极高,
两秒钟不到可以生成一百个内容不一单元格样式一模一样的Excel文件,NPOI不愧为操作xls的神器,
这样子可以省去大量的功夫,连字体大小字符居中还是靠右对齐、颜色都可以在模板设置好而无需通过NPOI设置,毕竟写代码设置单元格样式感觉是挺麻烦的事情
结束语
此解决方案只适合需要输出少量字符的情况,对于输出字符数量不确定的情况,因为可能会填满单元格导致列宽或者行高产生变化,
从而影响了打印预览等,对于这种情况由于没测试所以不进行描述。
- C#如何利用NPOI生成具有精确列宽行高的Excel文件
- C# WPF 利用NPOI读写Excel文件。
- C#利用NPOI操作excel
- C#生成excel-NPOI篇
- C#使用NPOI生成Excel
- NPOI根据Excel模板生成原生的Excel文件实例
- C#利用NPOI处理excel的类 NPOIHelper.cs
- NPOI之Excel——简单的使用NPOI读取和生成Excel文件
- 简单的使用NPOI读取和生成Excel文件
- C#操纵Excel-利用NPOI库
- .net利用npoi读取本地文件excel文件
- asp.net C# NPOI 读取 Excel 文件
- C# 用NPOI保存为Excel文件
- C# 使用NPOI操作Excel文件
- C#利用NPOI在同一个Excel文件中创建多个sheet
- NPOI锦囊:如何用NPOI生成可下载的Excel
- NPOI 生成Excel 的——常用
- NPOI 生成Excel 的——常用
- Eclipse导入Android项目提示:Invalid project description(解决方法)(
- 黑马训练营_线程的两种定义方法
- dmesg命令详解
- 黑马程序员_java基础day03
- ExtJs store传递给后台的参数使用POST方式
- C#如何利用NPOI生成具有精确列宽行高的Excel文件
- 嵌入式Linux:V4L2视频采集操作流程和接口说明
- JDBC中日期/时间的处理技巧
- vim编辑器的设置 记录
- 黑马程序员_java多线程的实现方法
- HEVC学习(十五) —— SAO函数解析之三
- uedit32的注册码及DOS/UNIX/MAC转换问题
- 罗马数字转十进制 古罗马帝国开创了辉煌的人类文明,但他们的数字表示法的确有些繁琐,尤其在表示大数的时候, 现在看起来简直不能忍受,所以在现代很少使用了。
- 《Head First设计模式》 读书笔记05 工厂模式(二)