C#如何利用NPOI生成具有精确列宽行高的Excel文件
2013-04-24 21:11
423 查看
前言
NPOI是操作Excel的神器,导出导入快如闪电,
但是SetColumnWidth函数个人感觉不会用,怎么弄都无法控制好,因为他是以字符数量去设置宽度,实际上Excel列宽还有个像素的概念,更搞不懂了
//附带SetColumnWidth的用法和注释
看着这注释我就觉得很蛋疼
遇到的问题
那么如果你需要生成固定格式的Excel,要有精确的列宽和行高,要用于打印等特殊需求,又如何解决呢
解决方案
哈哈,投机取巧之法,
建立一个已经设置好行高列宽的xls作为模板,在需要填充字符的地方随便填充一点字符(避免NPOI任务该单元格是NULL),设置好字体等内容,
利用NPOI打开这个xls文件,对对应的空格进行SetValue,然后保存文件,由于NPOI是对于文件流的操作而不是用Excel.exe去操作Excel,所以生成文件的效率极高,
两秒钟不到可以生成一百个内容不一单元格样式一模一样的Excel文件,NPOI不愧为操作xls的神器,
这样子可以省去大量的功夫,连字体大小字符居中还是靠右对齐、颜色都可以在模板设置好而无需通过NPOI设置,毕竟写代码设置单元格样式感觉是挺麻烦的事情
结束语
此解决方案只适合需要输出少量字符的情况,对于输出字符数量不确定的情况,因为可能会填满单元格导致列宽或者行高产生变化,
从而影响了打印预览等,对于这种情况由于没测试所以不进行描述。
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#基于NPOI生成具有精确列宽行高的Excel文件的方法
- asp.net Aspose.Word 利用邮件合并功能 操作word模板 生成word。asp.net NPOI 对excel进行操作,生成excel
- 如何利用QT设计师设计的ui生成相应头文件
- 如何利用iText在java程序中生成PDF文件
- Excel从另一个Excel文件中用户自定义区域(UsedRange)拷贝数据和行高、列宽
- 如何利用Framework模型生成IQD文件
- 如何利用ArcMap 10.1生成一个tpk文件
- C#利用NPOI在同一个Excel文件中创建多个sheet
- 生成了一个txt文件,如何用记事本和EXCEL 打开它给用户看?
- 【linux】如何利用mkfifo命令让程序产生的文件直接生成压缩文件
- 使用POI生成excel文件,可以自动调整列宽等
- org.in2bits.MyXls.XlsDocument 生成excel文件 ; 如果想读取模板再另外生成的话,试试 NPOI
- 数据模型是对象时如何利用freemarker生成静态文件
- 华为code craft软件精英赛笔记-如何在Linux下利用提供的shell文件生成tar.gz赛题提交压缩包
- 如何利用Hibernate配置文件生成数据库
- NPOI2.2.0.0实例详解(三)—设置EXCEL列宽、行高与合并单元格
- c#(winform,webform通用)利用npoi将xls文件复制为xlsx文件(excel的修改,保存,包括excel2003-office2007+的处理)
- c#如何生成Excel(.xls和.xlsx)文件
- 如何利用 myeclipse 生成Hibernate 配置文件