欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.NET使用報(bào)表工具FastReport實(shí)現(xiàn)打印功能

 更新時(shí)間:2022年03月09日 14:29:37   作者:.NET開發(fā)菜鳥  
這篇文章介紹了.NET使用報(bào)表工具FastReport實(shí)現(xiàn)打印功能的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

FastReport是功能非常強(qiáng)大的報(bào)表工具,在本篇文章中講解如何使用FastReport實(shí)現(xiàn)打印功能。

一、新建一個(gè)窗體程序,窗體上面有設(shè)計(jì)界面和預(yù)覽界面兩個(gè)按鈕,分別對(duì)應(yīng)FastReport的設(shè)計(jì)和預(yù)覽功能,其實(shí)現(xiàn)代碼如下:

using FastReport;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Dapper;

namespace FastReportDemo
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void btn_Design_Click(object sender, EventArgs e)
        {
            // 顯示設(shè)計(jì)界面
            CreateReport(true);
        }


        private void CreateReport(bool tfDesigin)
        {
            // 獲得當(dāng)前程序的運(yùn)行路徑
            string path = Application.StartupPath;
            // 定義報(bào)表
            Report report = new Report();
            string strDirectory = path + "\\ReportFiles";

            // 判斷文件路徑是否存在,不存在則創(chuàng)建文件夾
            if (!Directory.Exists(strDirectory))
            {
                // 不存在就創(chuàng)建目錄
                Directory.CreateDirectory(strDirectory);
            }

            // 判斷文件是否存在
            if (!File.Exists(strDirectory + "\\產(chǎn)品明細(xì).frx"))
            {
                report.FileName = strDirectory + "\\產(chǎn)品明細(xì).frx";
            }
            else
            {
                report.Load(strDirectory + "\\產(chǎn)品明細(xì).frx");
            }

            // 創(chuàng)建報(bào)表文件的數(shù)據(jù)源
            DataSet ds = new DataSet();
            DataTable dt = GetDataSource();
            DataTable dtSource = dt.Copy();
            dtSource.TableName = "ProductDetail";
            ds.Tables.Add(dtSource);
            report.RegisterData(ds);

            if (tfDesigin)
            {
                // 打開設(shè)計(jì)界面
                report.Design();
            }
            else
            {
                // 打開預(yù)覽界面
                report.Show();
            }
        }

        private DataTable GetDataSource()
        {
            DataTable dt = new DataTable();
            // 數(shù)據(jù)庫(kù)連接
            string strCon = @"Initial Catalog=StudentSystem;     Integrated Security=False;User Id=sa;Password=1qaz@WSX;Data Source=127.0.0.1;Failover Partner=127.0.0.1;Application Name=TransForCCT";
            SqlConnection conn = new SqlConnection(strCon);
            string strSql = @"SELECT p.ProductId,p.ProductName,p.Price,c.CategoryName FROM ProductDetail p INNER JOIN Category c
                              ON p.CategoryId=c.CategoryId";
            // 使用Dapper獲取數(shù)據(jù)
            IDataReader reader = conn.ExecuteReader(strSql);
            dt.Load(reader);
            return dt;
        }

        private void btn_Show_Click(object sender, EventArgs e)
        {
            // 顯示預(yù)覽界面
            CreateReport(false);
        }
    }
}

二、運(yùn)行程序,點(diǎn)擊設(shè)計(jì)界面,打開FastReport的設(shè)計(jì)界面:

三、選擇數(shù)據(jù)源

在設(shè)計(jì)之前要先選擇數(shù)據(jù)源,只有選擇了數(shù)據(jù)源,報(bào)表文件才會(huì)有數(shù)據(jù)。

1、在Data文件夾下面選擇“Choose Report Data”選項(xiàng):

2、在Choose Report Data界面選擇程序中要用到的數(shù)據(jù)源:

3、點(diǎn)擊“OK”按鈕以后,在設(shè)計(jì)界面的右側(cè)會(huì)顯示選擇的數(shù)據(jù)源:

四、報(bào)表的整體結(jié)構(gòu):

五、設(shè)計(jì)報(bào)表標(biāo)題

1、設(shè)計(jì)報(bào)表標(biāo)題要使用到“A”控件:

2、將左側(cè)的"A"控件拖拽到報(bào)表標(biāo)題區(qū)域:

3、設(shè)置標(biāo)題:

雙擊報(bào)表標(biāo)題區(qū)域的A控件,即可打開輸入標(biāo)題的界面:

4、輸入報(bào)表標(biāo)題,點(diǎn)擊“OK”按鈕:

報(bào)表標(biāo)題區(qū)域就會(huì)顯示設(shè)計(jì)的標(biāo)題,并可以設(shè)置標(biāo)題的對(duì)齊方式。

六:設(shè)計(jì)報(bào)表數(shù)據(jù)區(qū)域

1、設(shè)計(jì)報(bào)表數(shù)據(jù),要使用到表格控件,表格控件如下圖所示:

2、將表格拖拽到數(shù)據(jù)區(qū)域,設(shè)計(jì)表格要顯示的行數(shù)和列數(shù):

3、表格顯示的內(nèi)容:

4、表格界面:

七、設(shè)置表格事件

給表格添加數(shù)據(jù)綁定事件:

設(shè)置了事件以后,雙擊事件即可進(jìn)入代碼編輯界面,綁定事件的代碼如下:

using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.Windows.Forms;
using System.Drawing;
using System.Data;
using FastReport;
using FastReport.Data;
using FastReport.Dialog;
using FastReport.Barcode;
using FastReport.Table;
using FastReport.Utils;

namespace FastReport
{
  public class ReportScript
  {

    private void Table1_ManualBuild(object sender, EventArgs e)
    {
      // 設(shè)置數(shù)據(jù)源
      DataSourceBase rowData = Report.GetDataSource("ProductDetail"); 
      
      rowData.Init();
      
      Table1.PrintRow(0);
      Table1.PrintColumns();
      
      bool tfvar = false;
      while (rowData.HasMoreRows)
      {
        tfvar = true;
        Table1.PrintRow(1);
        Table1.PrintColumns();
        rowData.Next();
      }
      
      if (!tfvar)
      {
        Table1.PrintRow(2);
        Table1.PrintColumns();
      }
    }
  }
}

八、頁(yè)腳顯示打印時(shí)間:

九、保存報(bào)表格式

設(shè)計(jì)完報(bào)表格式以后,一定要記得保存:

十、效果

因?yàn)榻缑嫣?,所以分了兩個(gè)截圖顯示:

到此這篇關(guān)于.NET使用報(bào)表工具FastReport實(shí)現(xiàn)打印功能的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • EntityFramework 6.x學(xué)習(xí)之多個(gè)上下文遷移實(shí)現(xiàn)分布式事務(wù)詳解

    EntityFramework 6.x學(xué)習(xí)之多個(gè)上下文遷移實(shí)現(xiàn)分布式事務(wù)詳解

    這篇文章主要給大家介紹了關(guān)于EntityFramework 6.x學(xué)習(xí)之多個(gè)上下文遷移實(shí)現(xiàn)分布式事務(wù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • 通過(guò)jmeter壓測(cè)surging的方法

    通過(guò)jmeter壓測(cè)surging的方法

    Jmeter是Apache開源的一個(gè)使用純Java編寫的壓力測(cè)試工具,它最初是為測(cè)試web應(yīng)用程序而設(shè)計(jì)的,但后來(lái)擴(kuò)展到了其他測(cè)試功能,這篇文章主要介紹了通過(guò)jmeter壓測(cè)surging的相關(guān)知識(shí),需要的朋友可以參考下
    2022-07-07
  • 基于?.NET?6?的ASP.NET?Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序

    基于?.NET?6?的ASP.NET?Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序

    這篇文章主要介紹了ASP.NET?Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序,?.NET?6?使用了最小?WEB?API,?配置方式已經(jīng)部分發(fā)生了變化,下面文章我們來(lái)看看具體的方法,需要的小伙伴可以參考一下
    2022-03-03
  • 如此高效通用的分頁(yè)存儲(chǔ)過(guò)程是帶有sql注入漏洞的zt

    如此高效通用的分頁(yè)存儲(chǔ)過(guò)程是帶有sql注入漏洞的zt

    通常大家都會(huì)認(rèn)為存儲(chǔ)過(guò)程可以避免sql注入的漏洞,這適用于一般的存儲(chǔ)過(guò)程,而對(duì)于通用分頁(yè)存儲(chǔ)過(guò)程是不適合的,請(qǐng)看下面的代碼和分析!
    2010-07-07
  • asp.net+ajax+sqlserver自動(dòng)補(bǔ)全功能實(shí)現(xiàn)解析

    asp.net+ajax+sqlserver自動(dòng)補(bǔ)全功能實(shí)現(xiàn)解析

    這篇文章主要介紹了asp.net + ajax + sqlserver 自動(dòng)補(bǔ)全功能,需要的朋友可以參考下
    2014-03-03
  • 如何使用pm2守護(hù)你的.NET Core應(yīng)用程序詳解

    如何使用pm2守護(hù)你的.NET Core應(yīng)用程序詳解

    pm2是nodejs的一個(gè)帶有負(fù)載均衡功能的應(yīng)用進(jìn)程管理器的模塊,下面這篇文章主要給大家介紹了關(guān)于如何使用pm2守護(hù)你的.NET Core應(yīng)用程序的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-10-10
  • asp.net的GridView控件使用方法大全

    asp.net的GridView控件使用方法大全

    GridView控件是asp.net開發(fā)中經(jīng)常用到的控件之一,本網(wǎng)頁(yè)設(shè)計(jì)教程詳細(xì)介紹GridView的使用方法
    2013-04-04
  • EF?Core通過(guò)顯式編譯提高查詢性能

    EF?Core通過(guò)顯式編譯提高查詢性能

    這篇文章介紹了EF?Core通過(guò)顯式編譯提高查詢性能的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-02-02
  • ASP.NET?Core?6框架揭秘實(shí)例演示之如何承載你的后臺(tái)服務(wù)

    ASP.NET?Core?6框架揭秘實(shí)例演示之如何承載你的后臺(tái)服務(wù)

    這篇文章主要介紹了ASP.NET?Core?6框架揭秘實(shí)例演示之如何承載你的后臺(tái)服務(wù),主要包括利用承載服務(wù)收集性能指標(biāo)、依賴注入的應(yīng)用、配置選項(xiàng)的應(yīng)用等知識(shí)點(diǎn),本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03
  • .net等比縮放生成縮略圖的方法

    .net等比縮放生成縮略圖的方法

    本文給大家匯總了2個(gè)C#中等比縮放實(shí)現(xiàn)生成縮略圖的方法,第一種稍微簡(jiǎn)單些,第二種是本人常用的方法,這里推薦給大家,有需要的小伙伴可以參考下。
    2015-11-11

最新評(píng)論