FastReport使用方法(C/S版)


 前言

這兩天群里一直有群友問一些關於FastReport的問題,結合他們的問題,在這里做一個整理,有不明白的可以加

FastReport 交流群

554714044

工具

VS2017 +FastReport

 

開始

1.新建項目,添加三個按鈕。預覽、設計、打印

 

2.添加FastReport 引用,這里有三個dll文件

3.思路:首先打印要有模板,要有打印的數據,兩者結合呈現出我們想要的打印格式,然后進行各種操作。這個思路一定要清晰,這樣我們才能知道我們需要做什么。

話不多說上代碼:(這里只給出了最簡單的邏輯)

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using FastReport;

namespace FastReportTest
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        public string Url = "Test.frx";//文件路徑(目前存放在運行目錄下面,方便調試),后續建議做數據庫文件管理,存放在數據庫
        Report frt = new Report();

        /// <summary>
        /// 打印控件事件開始准備工作
        /// 獲取打印模板文件
        /// </summary>
        private void PrintPrepare()
        {
            frt.Load(Url);
            frt.RegisterData(PrintData(), "Tab1");
            frt.GetDataSource("Tab1").Enabled = true;
        }

        private void 預覽_Click(object sender, EventArgs e)
        {
           
            PrintPrepare();
            frt.Show();
        }

        private void 設計_Click(object sender, EventArgs e)
        {
            PrintPrepare();
            frt.Design();
        }

        private void 打印_Click(object sender, EventArgs e)
        {
            PrintPrepare();
            frt.PrintPrepared();
            frt.PrintSettings.ShowDialog = false;
            frt.Print();
        }

        /// <summary>
        /// 虛擬打印數據源、
        /// 數據源建議:
        /// 1.數據源最好在數據庫建立單獨的表管理,這樣每次要修改打印格式,不用編譯代碼,直接修改數據庫即可
        /// 2.多個數據源的,如果存在主從關系,建議建立視圖,直接查詢視圖,方便數據處理。
        /// 
        /// </summary>
        private DataTable PrintData()
        {
            DataTable dt = new DataTable();

            dt.Columns.Add("ID", typeof(int));
            dt.Columns.Add("Name", typeof(string));
            dt.Columns.Add("Price", typeof(decimal));

           
            for (int i = 0; i < 10; i++)
            {
                DataRow dr = dt.NewRow();
                dr["ID"] = i;
                dr["Name"] = "測試" + i.ToString();
                dr["Price"] = i * 10;
                dt.Rows.Add(dr);

            }

            return dt;
        }
    }
}

 

FastReport 設置

添加好以上的代碼,我們就可以運行看一下效果

File 

 

Save As :另存為,備份用,不多說

Page Setup:頁面設置,常用Paper:設置紙張規格 Margins:頁邊距

其余三個很少用到。

Printer Setup :打印機設置,這個界面我們可以在打印的時候默認不彈出,如果需要制定打印機或者其他信息,

可以把 frt.PrintSettings.ShowDialog = false; 改成 frt.PrintSettings.ShowDialog = true;即可

Edit

此部分不常用,略

View

這個我們經常用得到。F4 顯示屬性,Data 數據源,Toolbars 顯示工具欄

Insert 

插入一些特殊的格式或字體。其中Subreport 特別注意,我們有的時候需要添加側邊欄的時候用得到。BarCode 添加條形碼或者二維碼。

Report

Report 對應的內容 和點擊左邊Configure的效果是一樣的,都可以添加數據區控制部分。

左側Configure

點擊Configure 我們可以添加我們需要的數據分區,頁頭頁尾,行頭行尾,數據區,分組等

右側Data

此區域設置數據源,系統參數,合計,類型轉換。

DataSources 代表我們注冊進來的數據表

Variables 常用的 Row# 行號;Page# 當前頁;TotalPages#總頁數;

Totals 設置合計,計數,平均數,最大值,最小值使用。

Code

添加一些我們特殊處理的代碼,示例中我寫了一個金額大小寫轉換的例子

 #region 人民幣轉換
    decimal amount=0;
    private static string StrTran(string s, string oldv, string newv)
    {
      return s.Replace(oldv, newv);
    }

    /// <summary>
    /// 轉換大寫人民幣
    /// </summary>
    /// <param name="r"></param>
    /// <returns></returns>
    public static string RMBToString(decimal r)
    {
      decimal r1;
      string s1 = "零壹貳叄肆伍陸柒捌玖";
      string s2 = "分角元拾佰仟萬拾佰仟億拾佰仟萬";
      string dx, s;
      r1 = r;
      dx = "";
      if (r1 < 0)
      {
        r1 *= -1;
        dx = "";
      }
      s = String.Format("{0:f0}", r1 * 100);
      int len = s.Length;
      for (int i = 0; i < len; i++)
      {
        dx = dx + s1.Substring(s[i] - '0', 1) + s2.Substring(len - i - 1, 1);
      }
      dx = StrTran(StrTran(StrTran(StrTran(StrTran(dx, "零仟", ""), "零佰", ""), "零拾", ""), "零角", ""), "零分", "");
      dx = StrTran(StrTran(StrTran(StrTran(StrTran(dx, "零零", ""), "零零", ""), "零億", ""), "零萬", ""), "零元", "");
      if (dx == "")
        return "零元整";
      else
        return StrTran(StrTran(StrTran(dx, "億萬", "億零"), "零整", ""), "零零", "");
    }
    #endregion          
   

 

 

FastReport 交流群

554714044

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM