首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >c# ReportViewer出口

c# ReportViewer出口
EN

Stack Overflow用户
提问于 2013-02-19 09:03:15
回答 1查看 5.4K关注 0票数 1

ReportView中,我希望导出以下格式:.docx、.pdf或.xlsx

出口到.pdf:

代码语言:javascript
复制
reportViewer.ExportDialog(_reportViewer.LocalReport.ListRenderingExtensions()[3]);

出口到.docx:

代码语言:javascript
复制
reportViewer.ExportDialog(_reportViewer.LocalReport.ListRenderingExtensions()[5]);

出口到.xlsx:

代码语言:javascript
复制
reportViewer.ExportDialog(_reportViewer.LocalReport.ListRenderingExtensions()[1]);

但一开始,我必须选择一种保存格式。我希望首先打开SaveFileDialog,并在其中选择一种保存格式

我该怎么做呢?

EN

回答 1

Stack Overflow用户

发布于 2013-02-19 09:29:30

下面是我想出的代码:

代码语言:javascript
复制
string _sSuggestedName = String.Empty;

byte[] byteViewerPDF = _reportViewer.LocalReport.Render("PDF");  
byte[] byteViewerExcel = _reportViewer.LocalReport.Render("Excel");  
byte[] byteViewerWord = _reportViewer.LocalReport.Render("Word");

SaveFileDialog saveFileDialog1 = new SaveFileDialog();

saveFileDialog1.Filter = "PDF files (*.pdf)|*.pdf| Doc files
(*.doc)|*.doc| Excel files (*.xls)|*.xls";

if (saveFileDialog1.ShowDialog() == DialogResult.Ok)
{

  FileStream newFile = new FileStream(saveFileDialog1.FileName, FileMode.Create);

  if (saveFileDialog1.FilterIndex == 1)
  {
    newFile.Write(byteViewerPDF, 0, byteViewerPDF.Length);
    newFile.Close();
  }
  else
    if (saveFileDialog1.FilterIndex == 2)
    {
      newFile.Write(byteViewerWord, 0, byteViewerWord.Length);
      newFile.Close();
    }
  else
    if (saveFileDialog1.FilterIndex == 3)
    {
      newFile.Write(byteViewerExcel, 0, byteViewerExcel.Length);
      newFile.Close();
    }

}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14953524

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档