全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1023
推到 Plurk!
推到 Facebook!

QReport 如何將 Boolean 欄位在列表時改成中文的報表內容

答題得分者是:Justmade
bestlong
站務副站長


發表:126
回覆:734
積分:512
註冊:2002-10-19

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-03-26 16:33:17 IP:61.216.xxx.xxx 未訂閱
用 QReport 列印清單,因為其中有一欄位型態是 Boolean 的在預覽報表時該欄位都只顯示 True/False ,想改成 是/否 的顯示方式,不知道該如何處理... 我是雪龍
------
http://blog.bestlong.idv.tw/
http://www.bestlong.idv.tw/
http://delphi-ktop.bestlong.idv.tw/
Justmade
版主


發表:94
回覆:1934
積分:2030
註冊:2003-03-12

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-03-26 16:58:06 IP:218.16.xxx.xxx 未訂閱
在該 Band 內加入一個 TQRLabel (比如叫 QRLabel1) 在該 Band 的 BeforePrint 事件設定 :
if Table1.FieldByName(BooleanFieldName).Value then
  QRLabel1.Caption := '是'
else
  QRLabel1.Caption := '否';  
channel
尊榮會員


發表:67
回覆:707
積分:854
註冊:2002-05-02

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-03-26 16:59:53 IP:211.21.xxx.xxx 未訂閱
提供您兩個方法:
  • 您在TDataSet新增一個calculated欄位 cFieldName,再將TQRDBText指向這個欄位
    procedure TForm1.Query1CalcFields(DataSet: TDataSet);
    begin
      if DataSet.FieldByName('FieldName').AsBoolean = True then
        DataSet.FieldByName('cFieldName').AsString := '是'
      else
        DataSet.FieldByName('cFieldName').AsString := '否';
    end;
    
  • 利用TQRLabel元件
    procedure TForm1.QRLabel1Print(sender: TObject; var Value: String);
    begin
      if DataSet.FieldByName('FieldName').AsBoolean = True then
        QRLabel1.Caption := '是'
      else
        QRLabel1.Caption := '否';
    end;
    
~小弟淺見,參考看看~
------
~小弟淺見,參考看看~
bestlong
站務副站長


發表:126
回覆:734
積分:512
註冊:2002-10-19

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-03-26 18:14:41 IP:61.59.xxx.xxx 未訂閱
感謝兩位熱心的回答,問題解決了。我本來想也是這樣寫的也試了好些時間,原來是我把程式碼寫在不適當的事件. 我是雪龍
------
http://blog.bestlong.idv.tw/
http://www.bestlong.idv.tw/
http://delphi-ktop.bestlong.idv.tw/
系統時間:2024-04-26 7:04:38
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!