RLDC+ReportViewer做报表,客户要求不用预览就可以导出PDF和EXCEL,请教各位大侠如何实现?

tsyj216 2012-08-21 10:28:26
我用的是V studio.net 2010,我报表开发用的是2010里集成的RDLC+REPORTVIEER,现在客户要求不用预览就可以导出PDF和EXCEL,请问如何实现
...全文
8892 18 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
52cpp 2014-09-07
  • 打赏
  • 举报
回复

using System.Windows.Forms;
using Microsoft.Reporting.WinForms;
using System.IO;


        private void pdfExport()
        {
            //回写测试,如果可以回写到数据集中,然后更新RDLC,并输出,那么就用这种模式

            //refresh report viewer
            Warning[] warnings;
            string[] streamids;
            string mimeType;
            string encoding;
            string extension;

            byte[] bytes = this.reportViewer1.LocalReport.Render(
               "pdf", null, out mimeType, out encoding, out extension,
               out streamids, out warnings);

            FileStream fs = new FileStream(@"d:/output.pdf", FileMode.Create);
            fs.Write(bytes, 0, bytes.Length);
            fs.Close();

            MessageBox.Show("报表已经成功导出到桌面!", "Info");
            //ExportRpt(0); 
        }

yiyi0608 2013-08-09
  • 打赏
  • 举报
回复
LZ,最后怎么处理?可以分享么?求分享
zhangxu724100 2012-09-15
  • 打赏
  • 举报
回复
比如这个例子就可以:http://blog.csdn.net/ycz815/article/details/6934653
zhangxu724100 2012-09-15
  • 打赏
  • 举报
回复
http://blog.csdn.net/lvincent_china/article/details/7245274

这个是不预览直接打印的例子,改成不预览导出应该不难,思路是一样的。
tsyj216 2012-08-30
  • 打赏
  • 举报
回复
难道没一个人这么做过啊?唉
tsyj216 2012-08-30
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 的回复:]

C# code

Microsot.Reporting.WinForms.Warning[] Warnings;
string[] strStreamIds;
string strMimeType;
string strEncoding;
string strFileNameExtension;

byte[] bytes = this.rptViewer.LocalRep……
[/Quote]我还是不理解,不预览,就能实现点按钮直接保存EXCEL或者PDF吗
tsyj216 2012-08-30
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 的回复:]

C# code

Microsot.Reporting.WinForms.Warning[] Warnings;
string[] strStreamIds;
string strMimeType;
string strEncoding;
string strFileNameExtension;

byte[] bytes = this.rptViewer.LocalRep……
[/Quote]我还是不理解,不预览,就能实现点按钮直接保存EXCEL或者PDF吗
大Y 2012-08-29
  • 打赏
  • 举报
回复

Microsot.Reporting.WinForms.Warning[] Warnings;
string[] strStreamIds;
string strMimeType;
string strEncoding;
string strFileNameExtension;

byte[] bytes = this.rptViewer.LocalReport.Render("Excel", null, out strMimeType, out strEncoding, out strFileNameExtension, out strStreamIds, out Warnings);

string strFilePath = @"D:\report.xls";

using (System.IO.FileStream fs = new FileStream(strFilePath, FileMode.Create))
{
fs.Write(bytes, 0, bytes.Length);
}



蜡人张有讲过撒!


老龙友 2012-08-28
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 的回复:]

引用 7 楼 的回复:

reportView控件的导出功能用代码应该也可以实现,你可以参考下 http://blog.csdn.net/zhangzhiqiang813/article/details/2153934
直接用代码导出到目地位置,你也可以在代码里面加一个OpenFileDialog来指定导出的位置。
但是你的这周还得预览啊,不预览就不用吗,我窗体里就一个按钮【导出】,其……
[/Quote]

导出excel你会是吧?
那么:

1. 获取一个临时文件名
2. 用代码导出excel到临时文件名
3. 用代码打开excel,并打印,但这要求你的客户端装了Excel。。。

bevisliu 2012-08-28
  • 打赏
  • 举报
回复
应该可以不用ReportView控件,只需要能正确初始化ReportViewer对象就可以了
tsyj216 2012-08-27
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 的回复:]

reportView控件的导出功能用代码应该也可以实现,你可以参考下 http://blog.csdn.net/zhangzhiqiang813/article/details/2153934
直接用代码导出到目地位置,你也可以在代码里面加一个OpenFileDialog来指定导出的位置。
[/Quote]但是你的这周还得预览啊,不预览就不用吗,我窗体里就一个按钮【导出】,其他没有任何控件,请问我能实现吗》????
bevisliu 2012-08-26
  • 打赏
  • 举报
回复
reportView控件的导出功能用代码应该也可以实现,你可以参考下 http://blog.csdn.net/zhangzhiqiang813/article/details/2153934
直接用代码导出到目地位置,你也可以在代码里面加一个OpenFileDialog来指定导出的位置。
愚知 2012-08-24
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 的回复:]

怎么没一个人知道啊?
[/Quote].
知道数据源吗? 数据源到处为excel ,datatable to execl 会吗?
tsyj216 2012-08-24
  • 打赏
  • 举报
回复
怎么没一个人知道啊?
tsyj216 2012-08-24
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 的回复:]

引用 4 楼 的回复:

怎么没一个人知道啊?
.
知道数据源吗? 数据源到处为excel ,datatable to execl 会吗?
[/Quote]
大哥,你没明白的意思啊,我是利用报表做的分组啊,不是你理解那意思啊,datatable to execl 谁不会啊,我还用问吗,现在必须从报表里导出EXCE,并且不用预览,谁有办法啊,
tsyj216 2012-08-22
  • 打赏
  • 举报
回复
因为我的报表很多,客户嫌麻烦,不想预览,就可以一次把所有的报表导出EXCEL,明白我的意思吧
愚知 2012-08-21
  • 打赏
  • 举报
回复
生成报表后,报表上面有到处为excel和pdf的按钮,还用自己实现吗?
highreport 2012-08-21
  • 打赏
  • 举报
回复
是不是放到webbrower里面自动运行一下,然后在执行导出,蒙的

4,819

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 图表区
社区管理员
  • 图表区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧