C# NPOI生成的Excel文件 打印预览时出现很多空白页

xm3530 2017-08-17 11:48:04
一个简单导出excel功能,我们首先根据自定义模板生成了有数据的Excel文档,然后打开Excel文件,打印Excel文档。
在导入自定义模板的时候进行了打印预览,预览的页数为1。可是当我们通过NPOI插入数据以后生成的Excel文档,进行打印预览却有30页之多,多出的都是一些空白页。
在网上搜索了一下,原因大概是有些没有内容的单元格里有遗留的格式等等吧,但由于上传的文档是由客户自己编辑的。所以不可能做出很严格的限制。那么就要在生成Excel的时候做一些控制了。NPOI里有控制打印区域的方法SetPrintAre();但是要使用这个方法必须知道生成的Excel里有内容的区域范围。以下是我自己写的方法:

/// <summary>
/// 设置打印区域
/// </summary>
/// <param name="workbook"></param>
private void SetPrintArea(IWorkbook workbook)
{
int sheetCount = workbook.NumberOfSheets;
for (int i = 0; i < sheetCount; i++)
{
ISheet sheet = workbook.GetSheetAt(i);
int FirstRowNum = sheet.FirstRowNum;
int LastRowNum = sheet.LastRowNum;
int FirstCellNum = sheet.GetRow(FirstRowNum).FirstCellNum;
int LastCellNum = sheet.GetRow(LastRowNum).LastCellNum;
workbook.SetPrintArea(
i, //工作薄 下标0开始
FirstCellNum, //起始列 下标0开始
LastCellNum, //终止列 下标0开始
FirstRowNum, //起始行 下标0开始
LastRowNum //终止行 下标0开始
);
};
}

但这个方法并不能用,不能够准确的得到Excel里有内容部分的坐标。不知道大家有什么方法可以得到Excel里内容不为空的区域的坐标。如果有别的办法可以解决NPOI打印预览是出现很多空白页的方法也可以说一说。网上查了一下居然没有人提这个问题,难道很少人遇到吗?
...全文
1618 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
引用 4 楼 xm3530 的回复:
虽然我找到了问题所在,但是并不知道这种情况在代码里怎么解决。只能通过修改模板来消除。在这里记录一下吧。
导出 xlsx 就会报错,这说明 NPOI 有 bug。尽量不要使用。
guandy2015 2018-12-07
  • 打赏
  • 举报
回复
下标从零开始的。你减掉1就好


/// <summary>
/// 设置打印区域
/// </summary>
/// <param name="workbook"></param>
private void SetPrintArea(IWorkbook workbook)
{
    int sheetCount = workbook.NumberOfSheets;
    for (int i = 0; i < sheetCount; i++)
    {
        ISheet sheet = workbook.GetSheetAt(i);
        int FirstRowNum = sheet.FirstRowNum;
        int LastRowNum = sheet.LastRowNum;
        int FirstCellNum = sheet.GetRow(FirstRowNum).FirstCellNum;
        int LastCellNum = sheet.GetRow(LastRowNum).LastCellNum;
        workbook.SetPrintArea(
            i,             //工作薄 下标0开始
            FirstCellNum,  //起始列 下标0开始
            LastCellNum - 1,   //终止列 下标0开始
            FirstRowNum,   //起始行 下标0开始
            LastRowNum - 1     //终止行 下标0开始
        );
    };
}
kimuji 2018-01-17
  • 打赏
  • 举报
回复
mark 学习
  • 打赏
  • 举报
回复
请问,楼主会用npoi,打印生成的excel 吗。
xm3530 2017-08-25
  • 打赏
  • 举报
回复
过去了这么长时间仍然没有解决
xm3530 2017-08-25
  • 打赏
  • 举报
回复
虽然我找到了问题所在,但是并不知道这种情况在代码里怎么解决。只能通过修改模板来消除。在这里记录一下吧。
xm3530 2017-08-25
  • 打赏
  • 举报
回复
其实设置打印区域并不能解决我的问题。造成我问题的主要原因是通过NPOI 读写模板sheet后,生成Excel,导出后会多出来一些空白页,使用的模板在分页预览下只有一页,但生成的Excel里在分页预览下却不止一页,多出许多没有内容的空白页。网上有说使用ctrl+shift+右箭头,ctrl+shift+下箭头来删除一下模板,以确认使用的模板没有带有格式的空白单元格。实践之后仍然存在有空白的页,只是空白页的数量减少啦。
然后试着又自己修改了一下模板的内容,逐渐发现了问题的所在。模板里有这样一个问题单元格存在

这里备注栏下边的Remark超出了当前页。
使用这种问题模板,如果Excel是.xls导出时会有空白页出现。如下图

如果Excel是.xlsx导出时会报错,如下图,而且选择修复后会损失部分原来的格式,比如字体的加粗效果没有了。

选择修复后如图


最后我修改了模板,将此问题单元格改为自动换行,问题消失。
Hello World, 2017-08-17
  • 打赏
  • 举报
回复
如果是Aspose.cells倒是有方法来删除空行和空列: sheet.Cells.DeleteBlankRows(); sheet.Cells.DeleteBlankColumns(); NPOI就不知道了,如果没有的话自己写个循环来判断,为空就删除
与6.0版相比,控件6.01版的主要更改如下: 1、解决6.0版在XP及Windows Server 2008等操作系统下打印预览打印不正确的问题(第1页正常,其他各页全部是空白)。 控件主要功能: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印打印DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,基本上做到了所见即所得的打印。 2、报表设计功能。报表模板设计组件EasyReport可以设计普通报表、分组报表、套打模板等,以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、图表打印功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在打印控件中打印出来,也可以在Graphics对象中显示。 4、文本打印输出功能,控件提供多个文本打印重载函数,打印文本,如果需要,控件会自动换行和换页打印输出。还增加了以指定行间距及字符间距打印文本的功能,可以用固定行距,也可以用单倍或多倍行距打印文本。 5、绘图功能,基本上.NET的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 6、支持同一文档多种版面格式打印(类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边距),只需要在新增一页在NewPage方法中指定要使用的页面格式即可,使用非常简单。 7、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表打印内容。 8、数据导出功能,可以将DataGridView导出为Excel\PDF\RTF\HTML文件,5.7版控件使用开源的NPOI导出Excel,速度非常快,效果非常好。 9、强大的容器控件打印功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件中设计好要打印的内容及打印内容的相对位置,控件轻松帮你打印出来(如果超过一页,控件会自动换页续打)。 10、5.6版新增的SimpleReport组件允许您在一个方案文件中管理多个打印方案,在打印预览能自由在各个打印方案之间切换。 11、RichTextBox控件的RTF文本打印功能。 12、页眉页脚中既可打印文字,也可打印图像,或者即打印图像又打印输出文字。 13、多表头(跨行跨列的复杂表头)打印功能,多表头组件支持多表头显示与打印、单元格内容的合并显示、打印与导出。 14、自定义纸张支持功能。 15、直接打印窗口中的TreeView控件功能。 16、打印窗口中的ListView功能。 17、斜线表头打印功能。 18、各种条形码(包括二维码)打印功能。 19、5.7版控件增加了使用开源的NPOIExcel文件(支持2003与2007格式)中导入数据到DataGridView的功能,以及DataGridView的复制与粘贴功能。

62,054

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧