C#使用ReportViewer生成报表
知识点[转载]:ReportViewer :位于Microsoft.Reporting.WinForms命名空间, 主要用于报表的显示
Report:报表,以rdlc结尾的文件,可视化设计报表模板。
报表数据:内置字段,参数,图像,数据集(本报表主要使用参数,和数据集)
ReportParameter:使用名称和值实例化新的报表参数
ReportDataSource:报表的数据源与DataTable对象联系起来
效果图:
代码:
/// <summary>
/// 设置报表
/// </summary>
private void SetReport()
{
//第一步:清除之前的数据
this.rptView.LocalReport.DataSources.Clear();
//第二步:指定报表路径
this.rptView.LocalReport.ReportPath = "Report2.rdlc";
//第三步:构造新的DataTable
DataTable dt = new DataTable("DataTable1");
dt.Columns.Add("Name");
dt.Columns.Add("Score");
dt.Columns.Add("Id");
dt.Rows.Add(new object[] { "语文", 80, "Y0001" });
dt.Rows.Add(new object[] { "数学", 75, "S0001" });
dt.Rows.Add(new object[] { "英文", 96, "E0001" });
//名称不能写错,和报表中的数据集名称一致
ReportDataSource rdsItem = new ReportDataSource("DataSet1", dt);
//此处可以有多个数据源
this.rptView.LocalReport.DataSources.Add(rdsItem);
//第四步:构造参数
List<ReportParameter> lstParameter = new List<ReportParameter>() {
new ReportParameter("Title",this.txtTitle.Text),
new ReportParameter("Id",this.txtId.Text),
new ReportParameter("Name",this.txtName.Text),
new ReportParameter("Age",this.txtAge.Text),
new ReportParameter("Sex",this.txtSex.Text),
new ReportParameter("Salary",this.txtSalary.Text),
new ReportParameter("Depart",this.txtDepart.Text)
};
this.rptView.LocalReport.SetParameters(lstParameter);
this.rptView.ZoomMode = ZoomMode.Percent;
this.rptView.ZoomPercent = 100;
//第五步:刷新报表
this.rptView.RefreshReport();
}
qrwrwqrwqrw adsads 这种报表比较适合做餐厅的点菜打印,传的数据少 超市的也比较合适 剑弑 发表于 2017-5-26 11:41
这种报表比较适合做餐厅的点菜打印,传的数据少
没有列表的数据都比较适合 ibcadmin 发表于 2017-5-26 12:45
没有列表的数据都比较适合
嗯 看起来很高大上啊
页:
[1]