关于FastReport在winform中的使用(包含FastReport.net的安装步骤链接)
一、FastReport的简介
FastReport是功能齐全的报表控件,使开发者可以快速并高效地为·NET/VCL/COM/ActiveX应用程序添加报表支持。
二、FastReport的安装(推荐网址:https://www.cnblogs.com/yoyo-524/p/6116884.html)
感觉写的安装步骤很详细了,在这就不赘述了。另外提一个小问题,就是按照步骤我们安装好的是英文,怎么转成中文呢?
大家不用再去网上找中文破解包之类的,直接在菜单里找到“File”——>“Select Language”,然后选择我们需要的中文简体就OK了。
三、在Winform中使用FastReport
1、新建一个窗体,给窗体拖入
这个控件,
然后设置属性,最终成这样
2、新建一个frx报表,打开我们新安装的,打开之后选择“文件”——>“新建”,选择空报表。
然后给空报表选择数据源,如果不选则会报这个错
菜单“数据”——>“添加数据源”,然后就是一系列的选择数据库,写用户名,密码这类的,填写好后点击“下一个”,然后出现这个页面。
我需要的数据是用紫红色标出来的那四个字段,这里需要注意那个红色圈出的按钮“添加SQL查询...”(注:如果你需要的只是一个表里的全部或部分数据,那么直接点“完成”即可)
【这里修改一下哈,可以不勾选表里面的字段,然后直接点击“添加sql查询...”按钮的,这样在下面的数据源里就不会出现UserInfo和Dept这两个表了,直接一个Table就OK了】
点击这个按钮,然后“下一个”到这个页面
然后一直点击“下一个”直到完成。
然后就会发现报表右侧的数据源里多了个Table
然后将Table里面的字段直接拖入报表你想要显示数据的位置即可。
这个数据区显示的数据源,决定你报表显示的数据。这就是为什么非要把两个表里的字段整合到一个表中的原因。(有兴趣的自己试试,选择不同的数据区,导出的数据有什么区别)
【其实这个时候,你点击报表中的预览按钮已经能够显示出里面的数据了,当然,参数time的值除外。所以到这里我就迷惑了,都已经把数据源搞定了,我在代码里还折腾啥呢?但是一旦在报表中不给数据源,那里面的字段怎么拖进去?后续应该怎么做?这个有知道的希望能够留言解惑,拜托啦~】
报表模板就算做完了,然后保存,自己选个路径。然后我是又把它复制到了Reports这个文件夹里。在VS中打开frx报表,会以xml文件的形式打开。如果想要再次修改报表模板,可以选中
报表,右键选择打开方式,找到就OK了。还有一点需要注意,就是报表放进文件夹后需要右键属性,然后在“复制到输出目录中”一定要选成“始终复制”。
,要不然编译
report.Load(filename);//找不到文件,报错
的时候在bin\Debug\...文件目录下找不到报表文件,会报错。
3、代码,这里给报表附数据源,datatable和dataset都可以。
private void FormFR_Load(object sender, EventArgs e)
{
DataSet data = null;
string conStr = "Server='127.0.0.1';database=demo;UID='sa';PWD='wsn******';";
try
{
SqlConnection con = new SqlConnection(conStr);
con.Open();
string sql = @"select Dept.DeptID,Dept.DeptName,UserInfo.UserName,UserInfo.Salary from
dbo.Dept left join dbo.UserInfo on Dept.ID=UserInfo.DeptID";
SqlCommand sqlcmd = new SqlCommand(sql, con);
SqlDataAdapter sda = new SqlDataAdapter(sqlcmd);
data = new DataSet();
sda.Fill(data);
con.Close();
sda.Dispose();
}
catch (Exception err)
{
MessageBox.Show(err.StackTrace);
} try
{
FastReport.Report report = new FastReport.Report();
string filename = @"Reports\fr一览.frx"; report.Load(filename);
report.Preview = this.previewControl1;//让报表显示在窗体的控件中
report.RegisterData(data);
report.SetParameterValue("time", DateTime.Now.Date.ToString("yyyy-MM-dd"));//报表里的参数赋值
report.Prepare();
report.ShowPrepared();
}
catch (Exception err)
{
MessageBox.Show(err.Message);
}
}
最后报表显示的数据(因为页面太大,不能把前边的数据和操作时间截在一起,只能两张图了):
关于FastReport在winform中的使用(包含FastReport.net的安装步骤链接)的更多相关文章
- Windows中 MySQL5.7.17解压版安装步骤
1.先去MySQL官网下载.当前最新版是5.7.19,可能安装方法不同了,本人测试没有安装成功,若有安装成功的朋友,希望分享一下安装步骤. 个人推荐下载MySQL5.7.17,官方下载网址:https ...
- Winform中使用FastReport的DesignReport时怎样给通过代码Table添加数据
场景 FastReport安装包下载.安装.去除使用限制以及工具箱中添加控件: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- Winform中使用FastReport的DesignReport时怎样设置Table的size自动调整
场景 FastReport安装包下载.安装.去除使用限制以及工具箱中添加控件: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- Winform中在FastReport的PreviewControl预览控件中对report控件模板中控件值进行修改
场景 FastReport安装包下载.安装.去除使用限制以及工具箱中添加控件: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- Winform中使用FastReport实现自定义PDF打印预览
场景 Winform中使用FastReport实现简单的自定义PDF导出: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/1009 ...
- Winform中使用FastReport的PictureObject时通过代码设置图片源并使Image图片旋转90度
场景 FastReport安装包下载.安装.去除使用限制以及工具箱中添加控件: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/10 ...
- FastReport.net 绿色破解版winform中使用
FastReport 是非常有名的报表库,曾经在delphi中经常看到 现在FastReport.net 是.net平台下的实现.它的价格对于个人开发者来说确实非常非常贵 出于学习的目的(0<& ...
- 另一种在WINFORM中使用XNA的方法
之前在写化学分子模型制作程序的时候,使用一种方法,将WINFORM控件嵌入到XNA窗体中,从而实现了即使用WINFORM窗体控件又使用XNA.最近在写另一个物理运动学课件制作程序,同样使用XNA,但从 ...
- .net开发笔记(十八) winform中的等待框
winform中很多任务是需要在后台线程(或类似)中完成的,也就是说,经常容易涉及到UI界面与后台工作线程之间的交互.比如UI界面控制后台工作的执行(启动.暂停.停止等),后台工作进度在UI界面上的显 ...
随机推荐
- vue实战记录(一)- vue实现购物车功能之前提准备
vue实战,一步步实现vue购物车功能的过程记录,课程与素材来自慕课网,自己搭建了express本地服务器来请求数据 作者:狐狸家的鱼 本文链接:vue实战-实现购物车功能(一) GitHub:sue ...
- NOI真题记录
NOI2001 食物链,拓展域并查集. 炮兵阵地,棋盘状压DP. NOI2002 银河英雄传说,kruskal重构树/带权并查集. 贪吃的九头龙,树形DP. NOI2003 逃学的小孩,树形DP,二次 ...
- CentOS7 Zabbix3.4安装
依赖于lnmp或者lamp环境: 1.下载源码包 # wget -O zabbix-3.4.2.tar.gz http://sourceforge.net/projects/zabbix/files/ ...
- SQL学习指南第三篇
再谈连接 外连接 之前的范例都是没有考虑条件可能无法为表中的所有行匹配的问题 左外连接与右外连接 SELECT a.account_id, a.cust_id, b.name FROM account ...
- utf8mb4的大小写敏感性测试及其修改方法
utf8mb4的大小写敏感性测试及其修改方法 utf8mb4_ unicode_ ci 与 utf8mb4_ general_ ci 如何选择字符除了需要存储,还需要排序或比较大小,涉及到与编码字符集 ...
- IMPLEMENTING A GRU/LSTM RNN WITH PYTHON AND THEANO - 学习笔记
catalogue . 引言 . LSTM NETWORKS . LSTM 的变体 . GRUs (Gated Recurrent Units) . IMPLEMENTATION GRUs 0. 引言 ...
- [JDK8]性能优化之使用LongAdder替换AtomicLong
如果让你实现一个计数器,有点经验的同学可以很快的想到使用AtomicInteger或者AtomicLong进行简单的封装. 因为计数器操作涉及到内存的可见性和线程之间的竞争,而Atomic***的实现 ...
- VisualSVN服务器的本地搭建和使用
Subversion是优秀的版本控制工具,其具体的的优点和详细介绍,这里就不再多说. 首先来下载和搭建SVN服务器. 现在Subversion已经迁移到apache网站上了,下载地址: http:// ...
- spark JAVA 开发环境搭建及远程调试
spark JAVA 开发环境搭建及远程调试 以后要在项目中使用Spark 用户昵称文本做一下聚类分析,找出一些违规的昵称信息.以前折腾过Hadoop,于是看了下Spark官网的文档以及 github ...
- [物理学与PDEs]第2章习题2 质量力有势时的能量方程
试证明: 如果质量力有势, 即存在 $\phi$ 使 ${\bf F}=-\n \phi$, 那么理想流体的能量守恒方程的微分形式可写为 $$\bex \cfrac{\rd}{\rd t}\sex{e ...