c# - 从 c# 将 rdl 报告导出到多张 excel 文件有问题

标签 c# excel export export-to-excel rdlc

我一直在网上搜索这个问题的解决方案,但到目前为止还没有成功。

在我正在开发的当前应用程序中,我需要将可能较大的 rdlc 报告导出到 excel 文件(以及其他格式)

这是我用来实现此目的的代码,它在正常大小的报告上运行良好:

private static void ExportToExcel(LocalReport localReport, string filename)
{
  if (File.Exists(filename))
  { 
    File.Delete(filename);
  }

  var bytes = localReport.Render("Excel", string.Empty);
  using (var stream = File.Create(filename))
  {
    stream.Write(bytes, 0, bytes.Length);
  }
}

非常简单,但是当我尝试导出大型报告时,出现类似于以下内容的异常: “Excel 呈现扩展插件:行数超过了此版本工作表中可能的最大行数。请求的行数:152190。最大行数:65536。”

所以这是我的问题: 当达到最大行数时,有没有办法告诉导出商创建一个新的工作表?如果是这样,那是什么方式?

最佳答案

我遇到了类似的问题,我想在这里补充一下我的经验。由于未提及 SSRS 的版本并且问题仍未得到解答,我认为这是一个很好的地方。我编写了一个 PowerShell 脚本来将 SSRS 2012 rdl 报告导出为各种格式,其中一种是 Excel。我也收到以下错误:

Exception calling "Render" with "7" argument(s): "Excel Rendering Extension: Number of rows exceeds the maximum possible in a worksheet of this version. Rows requested: 65587. Maximum rows: 65536. (rrRenderingError)"

SSRS 2012 确实从 Excel 导出中删除了 65536 行限制,但我很难找到如何以编程方式突破此行限制。经过一番搜索,我遇到了 Microsoft Support Article这帮助我解决了它。需要将参数值“Excel”改为“EXCELOPENXML”

var bytes = localReport.Render("EXCELOPENXML", string.Empty);

同样,这对早期版本的 SSRS 没有帮助,但我想为 SSRS 2012 提供更多可见性。

关于c# - 从 c# 将 rdl 报告导出到多张 excel 文件有问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16191106/

相关文章:

c# - IServiceCollection 不包含 AddQuartz 的定义

vba - 当工作表有过滤器时,为什么 ActiveSheet.FilterMode 返回 False?

SQL Server 2012管理工作室: Export to Excel

mysql - 如何将大数据库导入到本地数据库

php - 使用php将mysql导出到xls(浏览器问题)

c# - 在 radGrid 中打印数据后允许分页 Telerik Asp.Net

c# - 在 C# 3.5 中将一种类型的列表转换为另一种类型的列表

javascript - 使用 Rollup.js 导出函数列表 - ECMA6 模块

c# - 多项式评估的生成方法

excel - 在 Excel 中转置数据集