⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 007.htm

📁 Delphi书籍--Delphi网上教程
💻 HTM
字号:
<HTML><HEAD><meta http-equiv="Content-Type" content="text/html; charset=GB2312"><TITLE>-->DELPHI专题文档-数据库应用-->在Delphi编制的程序运行中动态制作报表</TITLE>
<META NAME="keywords" CONTENT=" DELPHI专题文档-数据库应用 在Delphi编制的程序运行中动态制作报表">
<META NAME="description" CONTENT=" - DELPHI专题文档-数据库应用 - 在Delphi编制的程序运行中动态制作报表">

</HEAD>
<a href="index8.html">返回</a>

<body text="#000000" aLink=#9900ff link=#006699 vLink=#006699 bgcolor="#FFFFFF" leftmargin="3" topmargin="3" marginheight="3" marginwidth="3">
<TABLE WIDTH="100%" CELLPADDING=10 CELLSPACING=0 BORDER=0>
<TR>

<TD class="tt2" bgcolor="#F5F8F8" width="84%"><center><B><FONT style="FONT-SIZE: 16.5pt" COLOR="#FF6666" FACE="楷体_GB2312">在Delphi编制的程序运行中动态制作报表</FONT></B></center>
<hr color="#EE9B73" size="1" width="94%">
<BR>

<p><span style="font-size: 9pt">---- Delphi中的quickreport是挪威的QuSoft AS公司专门为Delphi设计的用于制作报表的组件,具有很强的访问数据库的能力。但是,从我个人的使用经验来看,这个组件的帮助写的不够详尽,例程也不多。因而一般编程人员都是在设计期间设计好报表的所有格式,并在运行时连上数据源(即delphi中的dataset)运行程序的。显然,这种方法不具备很强的灵活性。在这里我想向大家介绍一种在程序运行时如何动态制作报表的方法。 
<br> 
<br> 
---- 首先,建立form1;unit1(调用窗体),其中放入button1:caption为‘预览’,用以查看报表,再加入label1:caption为‘报表标题’;edit1用以接收用户输入的标题。再建立form2(放置quickreport元件的窗体),其中放入quickrep元件和三个qrband元件,其bandtype分别为rbTitle,rbColumnHeader,rbDetail.但其中无须放入qrlabel和qrdbtext元件,由程序中自动生成。再在form2;unit2中放入table1,table2。在databasename属性中填入数据库所在的Alias 
Name.在tablename中分别填入Goods,TableInformation.其中Goods中存放商品信息,可以设置以下字段:ID;Name;Unit;Price。TableInformation中的字段为TableName; 
FieldsName; DisplayName数据库中填入以下信息。 <br> 
<br> 
————————————————————————<br> 
Goods&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; ID 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 商品编号<br> 
Goods&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Name 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 商品名称<br> 
Goods&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Price 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 商品单价<br> 
<br> 
---- 好了,准备工作完成了一半,现在写入代码。在unit1的implementation下写入uses 
Unit2;在button1的click事件中写入以下代码: <br> 
&nbsp; begin<br> 
&nbsp;&nbsp; PreparePrint;<br> 
&nbsp;&nbsp; with Form2 do<br> 
&nbsp;&nbsp; begin<br> 
&nbsp;&nbsp;&nbsp;&nbsp; Preview;<br> 
&nbsp;&nbsp;&nbsp;&nbsp; Table1.Close;<br> 
&nbsp;&nbsp;&nbsp;&nbsp; Table2.Close;<br> 
&nbsp;&nbsp; end;<br> 
&nbsp; end;<br> 
<br> 
在unit1中添加一个过程PreparePrint;<br> 
<br> 
procedure TForm1.PreparePrint;<br> 
var LeftValue:integer;<br> 
&nbsp;&nbsp;&nbsp; aLabel : TQRLabel;<br> 
&nbsp;&nbsp;&nbsp; aText:TQRDBText;<br> 
begin<br> 
&nbsp; LeftValue:=100;<br> 
&nbsp; with Form2 do<br> 
&nbsp; begin<br> 
&nbsp;&nbsp;&nbsp; aLabel := TQRLabel.Create(Form2); '设置标题<br> 
&nbsp;&nbsp;&nbsp; aLabel.Parent := TitleBand1;<br> 
&nbsp;&nbsp;&nbsp; with aLabel do<br> 
&nbsp;&nbsp;&nbsp; begin<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Width:=300;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Height:=TitleBand1.Height;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Alignment:=taCenter;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Caption := Edit1.Text;<br> 
&nbsp;&nbsp;&nbsp; end;<br> 
&nbsp;&nbsp;&nbsp; Table1.Open;<br> 
&nbsp;&nbsp;&nbsp; Table2.Open;<br> 
&nbsp;&nbsp;&nbsp; Table2.First;<br> 
&nbsp;&nbsp;&nbsp; while not Table2.EOF do<br> 
&nbsp;&nbsp;&nbsp; begin<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; aLabel := TQRLabel.Create(Form2);<br> 
’设置显示字段标题<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; aLabel.Parent := HeaderBand1;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; with aLabel do<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; begin<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AutoSize:=False;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AutoStretch:=True;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Left :=LeftValue;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Top := 0;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Width:=80;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Height:=HeaderBand1.Height;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Alignment:=taCenter;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Caption := ' '+table2.FieldbyName(<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 'DisplayName').AsString+' ';<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; end;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; aText := TQRDBText.Create(Form2); <br> 
&nbsp;&nbsp; '设置显示字段内容<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; aText.Parent := DetailBand1;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; with aText do<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; begin<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AutoSize:=False;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; AutoStretch:=True;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Height:=DetailBand1.Height;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; DataSet:=Table1;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; DataField:=Table2.FieldbyName(<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 'FieldsName').AsString;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Alignment:=taCenter;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; end;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; LeftValue:=LeftValue+80;<br> 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; Table2.Next;<br> 
&nbsp;&nbsp;&nbsp; end;<br> 
&nbsp; end;<br> 
end;</span></p> 
<p><span style="font-size: 9pt"><br> 
---- 好了,运行程序可以看到报表预览的效果,显示了Goods中的ID,Name,Price。在运行时完全可以控制table1和table2中的数据内容。显示不同数据库的不同信息,改变table2中的记录顺序可改变报表中的显示顺序。而且,由于报表的各部分,甚至包括各band和system 
data均可在程序运行时依据上述方法动态生成。其属性也可动态设置。所以我们完全可以制作一个类似于Dephi中Form 
Wizard一样的报表精灵,还可提供一个灵活而且强大的打印设置功能。 
<br> 
---- 以上代码在delphi3中运行通过。 </span></p> 
<BR> 
<hr color="#EE9B73" size="1" width="94%"> 
 
</TD> 
 
</TR> 
</table> 
</BODY></HTML>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -