马上加入IBC程序猿 各种源码随意下,各种教程随便看! 注册 每日签到 加入编程讨论群

C#教程 ASP.NET教程 C#视频教程程序源码享受不尽 C#技术求助 ASP.NET技术求助

【源码下载】 社群合作 申请版主 程序开发 【远程协助】 每天乐一乐 每日签到 【承接外包项目】 面试-葵花宝典下载

官方一群:

官方二群:

C#使用ReportViewer生成报表

  [复制链接]
查看9583 | 回复7 | 2017-5-26 11:31:58 | 显示全部楼层 |阅读模式
知识点[转载]:

   ReportViewer :位于Microsoft.Reporting.WinForms命名空间, 主要用于报表的显示
   Report:报表,以rdlc结尾的文件,可视化设计报表模板。
   报表数据:内置字段,参数,图像,数据集(本报表主要使用参数,和数据集)
   ReportParameter:使用名称和值实例化新的报表参数
   ReportDataSource:报表的数据源与DataTable对象联系起来


效果图:




C#使用ReportViewer生成报表,www.ibcibc.com,c#教程

C#使用ReportViewer生成报表,www.ibcibc.com,c#教程




代码:

[C#] 纯文本查看 复制代码
/// <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();
        }






C#论坛 www.ibcibc.com IBC编程社区
C#
C#论坛
IBC编程社区
ibcadmin | 2017-5-26 11:32:40 | 显示全部楼层
qrwrwqrwqrw
C#论坛 www.ibcibc.com IBC编程社区
C#
C#论坛
IBC编程社区
法师法法师 | 2017-5-26 11:34:13 | 显示全部楼层
adsads
剑弑 | 2017-5-26 11:41:40 | 显示全部楼层
这种报表比较适合做餐厅的点菜打印,传的数据少
剑弑 | 2017-5-26 11:42:30 | 显示全部楼层
超市的也比较合适
ibcadmin | 2017-5-26 12:45:32 | 显示全部楼层
剑弑 发表于 2017-5-26 11:41
这种报表比较适合做餐厅的点菜打印,传的数据少

没有列表的数据都比较适合

点评

嗯  详情 回复 发表于 2017-6-5 09:23
C#论坛 www.ibcibc.com IBC编程社区
C#
C#论坛
IBC编程社区
剑弑 | 2017-6-5 09:23:22 | 显示全部楼层
ibcadmin 发表于 2017-5-26 12:45
没有列表的数据都比较适合

jakey0108 | 2017-7-12 17:39:04 | 显示全部楼层
看起来很高大上啊
*滑块验证:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则