C# winform打印excel的方法
更新时间:2020年12月15日 08:44:02 作者:wwachi
这篇文章主要为大家详细介绍了C# winform打印excel的方法,使用NPOI+Spire.xls+PrintDocument直接打印excel,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
前言
c#做winform程序要求生成并打印Excel报告,为了不安装Office相应组件,我选择了NPOI来生成Excel报告,用winform的PrintDocument控件来触发打印操作,而难点在于如何将excel转换成Graphics对象,在NPOI中我只找到了excel打印的设置(如横向/纵向),还需要打开excel去触发打印操作,但项目要求是一次性直接实现打印,要用PrintDocument控件而不是再去操作excel。不得已重新搜索,发现了类库Spire.xls,最终实现了要求。有什么错误或更简洁的方法还请广大博友不吝赐教。
思路
用npoi生成Excel =》 用spire.xls转换成图片.png =》 获取生成的图片,利用Graphic的drawimage方法对图片进行操作,当然了,如果不介意的话,可以不对图片进行操作:) =》使用printDocument控件的print方法实现打印( 当然这里可以直接用spire.xls直接生成Excel,但是Spire.xls的免费版本有每个sheet最多有150行的限制 )
知识点
【0】NPOI使用方法
下载:npoi.codeplex.com/releases/
【1】winform的printDocument控件
参考: docs.microsoft.com/en-us/dotnet/framework/winforms/advanced/how-to-print-a-multi-page-text-file-in-windows-forms
理解:
PrintDocument控件的作用是定义一个向打印机发送输出的对象,有BeginPrint,PrintPage,EndPrint方法,当执行printdocument.Print()语句时,会检查是否存在BeginPrint方法,存在则先调用。然后调用PrintPage方法,该方法会向PrintPageEcentArgs类中获得一个空白的Graphics对象,我们可以对Graphics对象进行操作(可以理解对画布进行绘制,Graphics对象有内置的类似DrawString,DrawPie的方法),在PrintPage方法的最后,会向打印设备发送这个Graphics对象。打印设备完成打印后,会检查是否存在EndPrint方法,存在则调用。
【2】spire.xls使用方法
参考:.NET读写Excel工具Spire.Xls使用入门教程(1)
具体代码
【1】winform使用的打印控件介绍
使用的插件截图
printDocument1作用:定义一个向打印机发送输出的对象
printPreviewDialog1作用:显示一个对话框,向用户显示关联文档打印的样子
printDialog1作用:显示一个对话框,允许用户选择打印机并选择其他打印选项(如分数,纸张方向)
【2】代码展示
“直接打印” 按钮的后台设置
private void DirectPrint_Click(object sender, EventArgs e)
{
isprint = false;
GenerateExcel_Click(sender, e); //使用NPOI生成excel
if (newsavefilepath != “” && isprint==true)
{
isprint = false;
ChangeExcel2Image(newsavefilepath); //利用Spire将excel转换成图片
if (printDialog1.ShowDialog() == DialogResult.OK)
{
printDocument1.Print(); //打印
}
}
}
“生成excel” 按钮后台设置
private void Generate_Click(object sender, EventArgs e)
{
CreateExcel(); //使用NPOI生成excel内容
SaveFileDialog savedialog = new SaveFileDialog(); //弹出让用户选择excel保存路径的窗口
savedialog.Filter = ” excel files(*.xlsx)|*.xlsx|All files(*.*)|*.*”;
savedialog.RestoreDirectory = true;
savedialog.FileName = string.Format(“销售订单审批单{0}”, DateTime.Now.ToString(“yyyyMMddHHmm”));
if (savedialog.ShowDialog() == DialogResult.OK)
{
//newsavefilepath是excel的保存路径
newsavefilepath = savedialog.FileName.ToString().Trim();
using (FileStream newfs = new FileStream(newsavefilepath, FileMode.Create, FileAccess.ReadWrite))
{
singlexssfwk.Write(newfs); //将生成的excel写入用户选择保存的文件路径中
newfs.Close();
}
}
}
CreateExcel()方法举例
using NPOI.XSSF.UserModel;
XSSFWorkbook singlexssfwk;
//注意,不同的NPOI版本调用的方法不一致,这里使用的版本是2.1.3.1
private void CreatExcel()
{
//获取模板excel的路径
string str = System.Environment.CurrentDirectory + “\\\\XXXX.xlsx”;
if (File.Exists(str))
{
using (FileStream fs = new FileStream(str, FileMode.Open, FileAccess.Read))
{
singlexssfwk = new XSSFWorkbook(fs);
fs.Close();
}
//获取表
XSSFSheet xssfsheet = (XSSFSheet)singlexssfwk.GetSheetAt(0);
//创建行
XSSFRow xssfrow1 = (XSSFRow)xssfsheet.GetRow(1);
//设置单元格内容
xssfrow1.GetCell(0).SetCellValue(“…”);
… …
}
else{
… …
}
}
ChangeExcel2Image()方法举例
using Spire.Xls;
public void ChangeExcel2Image(string filename)
{
Workbook workbook = new Workbook();
workbook.LoadFromFile(filename);
Worksheet sheet = workbook.Worksheets[0];
sheet.SaveToImage(imagepath); //图片后缀.bmp ,imagepath自己设置
}
执行printDocument1.Print()的方法会调用printDocument1_PrintPage方法
//在PrintPage方法中写截取图片 的代码
private void printDocument1_PrintPage(object sender, System.Drawing.Printing.PrintPageEventArgs e)
{
#region 如果不需要截取图片,可以不用写以下代码
GC.Collect();
Graphics g = e.Graphics;
//imagepath是指 excel转成的图片的路径
using (Bitmap bitmap = new dBitmap(imagepath))
{
//如何截取自己摸索
Rectangle newarea = new Rectangle();
newarea.X = 0;
newarea.Y = 50;
newarea.Width = bitmap.Width;
newarea.Height = bitmap.Height – 120;
using (Bitmap newbitmap = bitmap.Clone(newarea, bitmap.PixelFormat))
{
g.DrawImage(newbitmap, 0, 0, newbitmap.Width – 200, newbitmap.Height – 150);
}
}
#endregion
}
备注:关于预览的设置,关键在于printDocument1是个全局对象,直接设置printPreviewDialog1.Document = printDocument1; printPreviewDialog1.ShowDialog();即可,这个的原理没有研究,反正这样设置后,只要你处理好内容,就能在预览中看到。
总结
以上就是我实现c# winform打印excel的经过,或许这只是一种比较冗杂的方法,如果有大佬有更精简的方法,请不吝赐教。如有错误,也请不吝赐教。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持华域联盟。
您可能感兴趣的文章:c# 实现打印机状态查询与阻塞打印c#使用Aspose打印文件的示例C# 调用exe传参,并获取打印值的实例如何利用C#打印九九乘法表c# winform 解决PictureBox 无法打印全部图片的问题C#操作Word打印的示例C#操作excel打印的示例C# 打印网页不显示页眉页脚的实现方法C#实现扫描枪扫描二维码并打印(实例代码)C#利用PrintDocument定制打印单据的小例子C#打印PDF文档的10种方法(小结)C# TSC打印二维码和条形码的实现方法c# 如何实现web打印插件
c#
winform
excel
相关文章
asp.net+js实现的ajax sugguest搜索提示效果阿会楠根据网上一份原作者不详的代码进行了修改,以适合自己的项目并增加了多个功能。此次放出的代码为基本实现代码,也是最接近原来的代码,略去其他功能。版权归原作者所有。 2009-04-04
ASP.NET Core静态文件的使用方法这篇文章主要给大家介绍了关于ASP.NET Core静态文件的使用方法,文中通过示例代码介绍的非常详细,对大家学习或者使用ASP.NET Core具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧 2019-05-05
Linq to XML 用一句话读出RSS文章列表代码Linq to XML 用一句话读出RSS文章列表代码 2010-06-06
asp.net mvc 动态编译生成Controller的方法本篇文章主要介绍了asp.net mvc 动态编译生成Controller的方法,具有一定的参考价值,有兴趣的可以了解一下
2017-08-08
Asp.Net中文本换行Asp.Net中文本换行… 2007-04-04
Web Services使用多态的方法Web Services可以支持多态,不过仅仅限制在可以直接引用Web Services的时候,本文也只是起到抛砖引玉的效果, 2015-10-10
ASP.NET MVC5网站开发我的咨询列表及添加咨询(十二)这篇文章主要介绍了ASP.NET MVC5网站开发我的咨询列表及添加咨询 2015-09-09
.Net中实现无限分类的2个例子这篇文章主要介绍了.Net中实现无限分类的2个例子,本文直接给出实现代码,需要的朋友可以参考下 2015-02-02
ASP.Net页尾中添加JavaScript的最佳方法实战分享将JavaScript脚本或库添加到asp.net页的末尾方法有很多,究竟哪一个最好使呢有利于日后的维护啊,是个疑点啊,本文的出现将帮你解决所有的困惑,感兴趣的你可不要错过了哈 2013-02-02
linq to sql中,如何解决多条件查询问题,答案,用表达式树!有个小项目中,用到了linq to sql,既然这样,想必需要做多条件组合查询了,虽然我对表达式树的研究也只是寥寥地,但除此方法,似乎别无他法,只好硬着头皮研究一下. 2011-08-08
最新评论

评论(0)