ASP.NET水晶报表实现打印功能

 

ASP.NET下的水晶报表打印,据我所知有以下几种办法可以打印:

1.用IE的打印,调用window.print(),但这种办法对于页面上即有报表,又有其它控件情况就无法区分,不能达到只打印报表内容的目的;

2.自已写打印代码

代码如下:

以下为引用的内容:
CrystalDecisions.CrystalReports.Engine.ReportDocument rd=new CrystalDecisions.CrystalReports.Engine.ReportDocument(); 
rd.Load(Server.MapPath("Crystalreport1.rpt")); 
rd.PrintOptions.PrinterName="打印机名称"; 
rd.PrintToPrinter(1,true,0,0); 

其中"打印机名称":如果是网络打印机,在打印机名称前面要加上"\\机器名".本地打印机也可以显示在DropDownList控件里让用户选择:

以下为引用的内容:
foreach(string iprt in System.Drawing.Printing.PrinterSettings.InstalledPrinters) 
this.DropDownList1.Items.Add(iprt); 

PrintDoc.PrintOptions.PrinterName = DropDownList1.Text

这个办法可以只打印报表中的内容,缺点就是必须指明打印机名称.如果是本地打印机还好办,可以枚举出来,让用户选择.

如果不设置指定打印机,将会从服务器设置的默认打印机打印,以下为找到默认打印机的源代码.

以下为引用的内容:
Dim prt As New System.Drawing.Printing.PrinterSettings

Dim strDefaultPrinterName As String = prt.DefaultPageSettings.PrinterSettings.PrinterName

3.导出到PDF或EXCEL或其它格式的文件打印.示例代码如下:
报表名称 myrpt=new 报表名称();

以下为引用的内容:
myrpt.ExportOptions.ExportDestinationType=CrystalDecisions.Shared.ExportDestinationType.DiskFile; 
myrpt.ExportOptions.ExportFormatType=CrystalDecisions.Shared.ExportFormatType.PortableDocFormat; 
CrystalDecisions.Shared.DiskFileDestinationOptions opt=new CrystalDecisions.Shared.DiskFileDestinationOptions(); 
opt.DiskFileName=@"文件名"; 
myrpt.ExportOptions.DestinationOptions =opt; 
myrpt.Export(); 

原文地址:https://www.cnblogs.com/alex_c/p/1951826.html
分类: IT技术文章
 
posted @   scoluo  阅读(351)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示