winform-WinForm怎么使用FastReport报表工具导出Excel

如题所述

DataSet数据集内数据转化为Excel文件
/// <summary>
/// ExportFiles 的摘要说明。
/// 作用:把DataSet数据集内数据转化为Excel文件
/// 描述:导出Excel文件
/// 备注:请引用Office相应COM组件,导出Excel对象的一个方法要调用其中的一些方法和属性。
/// </summary>
public class ExportFiles
{
private string filePath = "";
public ExportFiles(string excel_path)
{
//
// TODO: 在此处添加构造函数逻辑
//
filePath = excel_path;
}
/// <summary>
/// 将指定的Dataset导出到Excel文件
/// </summary>
/// <param name="dt"></param>
/// <returns></returns>
public bool ExportToExcel(System.Data.DataSet ds, string ReportName)
{
if (ds.Tables[0].Rows.Count == 0)
{
MessageBox.Show("数据集为空");
}
Microsoft.Office.Interop.Excel._Application xlapp = new ApplicationClass();
Workbook xlbook = xlapp.Workbooks.Add(true);
Worksheet xlsheet = (Worksheet)xlbook.Worksheets[1];
Range range = xlsheet.get_Range(xlapp.Cells[1, 1], xlapp.Cells[1, ds.Tables[0].Columns.Count]);
range.MergeCells = true;
xlapp.ActiveCell.FormulaR1C1 = ReportName;
xlapp.ActiveCell.Font.Size = 20;
xlapp.ActiveCell.Font.Bold = true;
xlapp.ActiveCell.HorizontalAlignment = Microsoft.Office.Interop.Excel.Constants.xlCenter;
int colIndex = 0;
int RowIndex = 2;
//开始写入每列的标题
foreach (DataColumn dc in ds.Tables[0].Columns)
{
colIndex++;
xlsheet.Cells[RowIndex, colIndex] = dc.Caption;
}
//开始写入内容
int RowCount = ds.Tables[0].Rows.Count;//行数
for (int i = 0; i < RowCount; i++)
{
RowIndex++;
int ColCount = ds.Tables[0].Columns.Count;//列数
for (colIndex = 1; colIndex <= ColCount; colIndex++)
{
xlsheet.Cells[RowIndex, colIndex] = ds.Tables[0].Rows[i][colIndex - 1];//dg[i, colIndex - 1];
xlsheet.Cells.ColumnWidth = ds.Tables[0].Rows[i][colIndex - 1].ToString().Length;
}
}

xlbook.Saved = true;
xlbook.SaveCopyAs(filePath);
xlapp.Quit();
GC.Collect();
return true;
}

public bool ExportToExcelOF(System.Data.DataSet ds, string ReportName)
{
if (ds.Tables[0].Rows.Count == 0)
{
MessageBox.Show("数据集为空");
}
string FileName = filePath;

//System.Data.DataTable dt = new System.Data.DataTable();
FileStream objFileStream;
StreamWriter objStreamWriter;
string strLine = "";
objFileStream = new FileStream(FileName, FileMode.OpenOrCreate, FileAccess.Write);
objStreamWriter = new StreamWriter(objFileStream, System.Text.Encoding.Unicode);

strLine = ReportName;
objStreamWriter.WriteLine(strLine);
strLine = "";

for (int i = 0; i < ds.Tables[0].Columns.Count; i++)
{
strLine = strLine + ds.Tables[0].Columns[i].ColumnName.ToString() + " " + Convert.ToChar(9);
}
objStreamWriter.WriteLine(strLine);
strLine = "";

for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
strLine = strLine + (i + 1) + Convert.ToChar(9);
for (int j = 1; j < ds.Tables[0].Columns.Count; j++)
{
strLine = strLine + ds.Tables[0].Rows[i][j].ToString() + Convert.ToChar(9);
}
objStreamWriter.WriteLine(strLine);
strLine = "";
}
objStreamWriter.Close();
objFileStream.Close();

//Microsoft.Office.Interop.Excel._Application xlapp = new ApplicationClass();
//Workbook xlbook = xlapp.Workbooks.Add(true);
//Worksheet xlsheet = (Worksheet)xlbook.Worksheets[1];
//Range range = xlsheet.get_Range(xlapp.Cells[1, 1], xlapp.Cells[1, ds.Tables[0].Columns.Count]);
//range.EntireColumn.AutoFit();
//xlapp.Quit();
return true;
}
}
温馨提示:内容为网友见解,仅供参考
第1个回答  2017-10-22
约翰终于跑起来,
要我穿过,去一片没有
在冒险中,罗盘疯狂地转变方向
当我们在世间已不再存在,
不上骗子的当的议员。
品味是的活的波澜壮阔哈哈

Delphi FastReport 报表导出到 Excel 上面
那为何不直接将查询结果导成Excel,反而需要生成报表后再导出到Excel。

C# winform 调用Fastreport报表fr3模版
FastReort.Net版本在设计好frx文件后,就是两句:report.Register(dataSet);\/\/注册数据源 report.Load(ms);\/\/frx文件流

最强报表工具,试试新版本的FastReport.Net
FastReport.Net,一款强大的报表工具,迎来了新版本的升级。它支持Windows Forms、ASP.NET、MVC和.NET Core平台,能在Visual Studio 2005-2019环境中高效运行,兼容.NET Framework 2.0-4.x和.NET Core 2.0。新版本显著改进了多边形功能,引入了贝塞尔曲线和全新的编辑模式。你可以现在整个多边形上操作,...

报表控件FastReport使用指南-在Ubuntu LTS中创建PDF文档
首先,确保开发者在其计算机上安装了JetBrains Rider IDE,并适应Linux环境。Ubuntu 22.04.1 LTS系统可能需要额外的库,可使用控制台进行Linux设置。创建新的解决方案后,选择.NET\/.NET Core下的Console Application项目类型,命名项目(如“ReportPDF_Core_ConsoleApp”),并配置语言为C#,框架为“.NET ...

fastreport怎么实现网口打印
FastReport .NET(WinForm)使用FastReport.Net在WinForm平台上进行报表开发,实现直接打印的方式和VCL相识,将PrintSettings对话框设置为False就行了,也可以使用以下代码实现。Report report = new Report();report.Load(...);report.RegisterData(...);report.PrintSettings.ShowDialog = false;report....

免费试用正版报表分析工具FastReport .NET
FastReport .NET 2020.4引入了ITF-14和Deutsce Post Identcode条形码,提供报告图像存储格式选择,通过鼠标拖动调整表格行数和列数。支持PDF\/A-2u格式导出,新增恶意代码检测功能。新演示应用程序提供更佳视觉效果和便捷使用体验。在黑色界面下,功能一目了然。白色界面同样展示其全面性:设计、导出、Web...

Net下报表控件哪个好
一、支持的开发环境 FastReport .NET官方显示当前支持WinForm和Asp.NET两种模式。二、报表设计器 和FastReport VCL一样,.NET版也为开发者提供了一个报表模版设计器,这个设计器既可以在Visual Studio集成环境中打开,也可以独立打包成一个应用程序。当然你想打包成独立的应用程序需要购买专业版以上版本,...

c# WinForm 条形码怎么生成?原理是什么?
比如 最好用的应该是FastReport(报表设计工具),直接拖拉条形码控件到报表设计面板,填入你要打印的条形码数值,它就自动生成了,然后调用fastReport的打印方法即可,网上资料也很多。4 还有一种方法是条形码字体 网上可以找到code128或code39的条形码字体,填入数值就可以生成条形码,然后像打印其他普通的内容一样...

报表工具 Fastreport Delphi 和 Lazarus 产品更新至 2024.2 版本_百度知...
报告导出功能得到了改进,包括 PDF、HTML5、SVG、DOCX 和 XLSX 的导出质量得到优化。在 Linux 平台上,WINE 操作得到了全面优化。FastCube 的错误修复和与通用代码库的集成改善了使用体验。FastReport FMX 添加了 DOCX 和 XLSX 导出过滤器,便于将报告转换为所需格式。值得注意的是,从 2024.2 版本开始...

5个面向开发人员的顶级报表工具
使用 FastReport.Net,可以创建独立于应用程序的.Net 报表,或作为独立的报表工具使用。最新版FastReport 可以在官网下载试用。Teechart 是全球领先的图表类控件,提供交互性强的TeeChart Pro ActiveX 和功能齐全的工业4.0 WinForm图表控件 TeeChart for .NET。通过 TeeChart for .NET,可以轻松创建或连接...

相似回答