vs 2015 rdlc报表绑定datagridview中的数据
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vs 2015 rdlc报表绑定datagridview中的数据相关的知识,希望对你有一定的参考价值。
这几天一直想要实现rdlc报表绑定datagridview中的数据,始终在虚拟表向rdlc报表绑定这一步上出错。今天从下午4点到七点四十一直在尝试。最终还是实现了,最然并不知所以然,这个问题还是以后在考虑吧,目前的项目要紧。
首先是 datagridview中的数据传到虚拟表中。
for (int i = 0; i < dgvscan.Columns.Count - 1; i++)
{
dtout.Columns.Add(dgvscan.Columns[i].Name);
}
//添加行
for (int j = 0; j < dgvscan.Rows.Count - 1; j++)
{
DataRow dr = dtout.NewRow();
for (int k = 0; k < dgvscan.Columns.Count - 1; k++)
{
dr[k] = dgvscan.Rows[j].Cells[k].Value;
}
dtout.Rows.Add(dr);
}
reportout frmReporterOut = new reportout(dtout);
frmReporterOut.Show();
然后是虚拟表绑定到报表
private void reportout_Load(object sender, EventArgs e)
{
ReportDataSource rdlc = new ReportDataSource("DataSet2", dtout);
reportViewer1.LocalReport.DataSources[0] = rdlc; //最好不要用add ----假设此行行数为n
//this.reportViewer1.LocalReport.DataSources.Add(new ReportDataSource("DataSet2", dtout));//之前这句代码一直不行
this.reportViewer1.RefreshReport();
}
最开始 上面注释掉的那行代码总是实现不了功能,换了一行才行,然而并不知道为什么。
忽然一想,
reportViewer1.LocalReport.DataSources.Clear();
this.reportViewer1.LocalReport.DataSources.Add(rdlc);
这样就可以了,试了一下真可以。最开始应该是在控件编辑的时候为rdlc绑定了数据源,需要重新清除重新绑定。单纯的add无法实现数据源的覆盖
以上是关于vs 2015 rdlc报表绑定datagridview中的数据的主要内容,如果未能解决你的问题,请参考以下文章