打印水晶报表
下载一个水晶报表安装包,安装完了就可以用了。
水晶报表的打印其实跟我们写的导出有点类似,我们要保证现在在页面查询出来的数据和我们打印出来的保证一致,所以我们要再查下一次。
打印水晶报表:
function printAchievement() {
//获取查询条件
var academeId = $("#sltAcademe").val();
var gradeId = $("#sltGrade").val();
var classId = $("#sltClass").val();
//判断
if (academeId == “” || academeId == undefined) {
academeId = 0;
}
if (gradeId == “” || gradeId == undefined) {
gradeId = 0;
}
if (classId == “” || classId == undefined) {
classId = 0;
}
这个就是打印水晶报表的方法:
layer.confirm(“确定要打印当前表格中的数据吗?是请点击确定,否则请先筛选数据再进行打印!”, { icon: 3, title: “提示” }, function (layIndex) {
layer.close(layIndex);
window.open(“PrintAchievement?AcademeID=” + academeId + “&GradeID=” + gradeId + “&ClassID=” + classId);
});
}
然后到控制器给这个水晶报表设置数据源以及画水晶报表的模板。
这个表格是我们自己画出来的,是怎么画的呢,我们先在本区域里建一个文件夹,文件夹里放两个东西,一个是数据源,另一个是水晶报表的模板。我们就是在水晶报表的模板里画出我们所需要的表格。下面的水晶报表的模板,要怎么去画自己去查查一下,我这里就不多说明了。
控制器写打印水晶报表的方法:
将查询出来的数据转化为DataTable的格式
DataTable dtResult = LINQToDataTable(listResult);
1、实例化数据集
PrintReport.ReportDB dbReport = new PrintReport.ReportDB();
2、将dtResult放入数据集中名为“tbAchievement”的表格中
dbReport.Tables[“tbAchievement”].Merge(dtResult);
3、实例化数据报表
PrintReport.AchievementReport rp = new PrintReport.AchievementReport();
4、获取报表的物理文件路径
string strRpPath = Server.MapPath("~/") + “Areas\ExaminationManagement\PrintReport\AchievementReport.rpt”;
5、将报表加载到报表模板中
rp.Load(strRpPath);
6、设置报表的数据源
rp.SetDataSource(dbReport);
7、将报表转化为文件流输出
Stream dbStream = rp.ExportToStream(CrystalDecisions.Shared.ExportFormatType.PortableDocFormat);
return File(dbStream, “application/pdf”);