U_general_print.pas
上传用户:psxgmh
上传日期:2013-04-08
资源大小:15112k
文件大小:9k
源码类别:

Delphi/CppBuilder

开发平台:

Delphi

  1. unit U_general_print;
  2. interface
  3. uses
  4.   Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  5.   StdCtrls, Buttons, ExtCtrls, ComCtrls, Db, DBClient, variants;
  6. type
  7.   TfrmPrint = class(TForm)
  8.     StatusBar1: TStatusBar;
  9.     Panel1: TPanel;
  10.     SrcLabel: TLabel;
  11.     DstLabel: TLabel;
  12.     IncludeBtn: TSpeedButton;
  13.     IncAllBtn: TSpeedButton;
  14.     ExcludeBtn: TSpeedButton;
  15.     ExAllBtn: TSpeedButton;
  16.     Label2: TLabel;
  17.     Label3: TLabel;
  18.     SrcList: TListBox;
  19.     DstList: TListBox;
  20.     Panel2: TPanel;
  21.     btnOK: TSpeedButton;
  22.     btnCancel: TSpeedButton;
  23.     Panel3: TPanel;
  24.     Label1: TLabel;
  25.     edtPrintTitle: TEdit;
  26.     Panel4: TPanel;
  27.     Label4: TLabel;
  28.     edtLister: TEdit;
  29.     Label5: TLabel;
  30.     edtListDate: TEdit;
  31.     ClientDataSet: TClientDataSet;
  32.     procedure IncludeBtnClick(Sender: TObject);
  33.     procedure ExcludeBtnClick(Sender: TObject);
  34.     procedure IncAllBtnClick(Sender: TObject);
  35.     procedure ExcAllBtnClick(Sender: TObject);
  36.     procedure FormActivate(Sender: TObject);
  37.     procedure ExAllBtnClick(Sender: TObject);
  38.     procedure DstListDblClick(Sender: TObject);
  39.     procedure SrcListDblClick(Sender: TObject);
  40.     procedure btnCancelClick(Sender: TObject);
  41.     procedure btnOKClick(Sender: TObject);
  42.   private
  43.     varexcel: variant; //变体变量,指向创建的EXCEL对象
  44.     range: variant; //变体变量,作为EXCEL一块区域的对象
  45.     procedure GetData; //得到数据
  46.     procedure ExportDataToExcel; //打印数据
  47.     { Private declarations }
  48.   public
  49.     vps_tablename: string; //打印报表的数据源的表名称
  50.     vps_filter: string; //打印报表的数据源的表过滤条件
  51.     vps_index: string; //打印报表的数据源的索引
  52.     { Public declarations }
  53.     procedure MoveSelected(List: TCustomListBox; Items: TStrings);
  54.     procedure SetItem(List: TListBox; Index: Integer);
  55.     function GetFirstSelection(List: TCustomListBox): Integer;
  56.     procedure SetButtons;
  57.   end;
  58. var
  59.   frmPrint: TfrmPrint;
  60. implementation
  61. uses comobj, excel97, u_public, U_mainform;
  62. {$R *.DFM}
  63. //==========================
  64. //操作两个列表框之间的数据移动
  65. procedure TfrmPrint.IncludeBtnClick(Sender: TObject);
  66. var
  67.   Index: Integer;
  68. begin
  69.   Index := GetFirstSelection(SrcList);
  70.   MoveSelected(SrcList, DstList.Items);
  71.   SetItem(SrcList, Index);
  72. end;
  73. procedure TfrmPrint.ExcludeBtnClick(Sender: TObject);
  74. var
  75.   Index: Integer;
  76. begin
  77.   Index := GetFirstSelection(DstList);
  78.   MoveSelected(DstList, SrcList.Items);
  79.   SetItem(DstList, Index);
  80. end;
  81. procedure TfrmPrint.IncAllBtnClick(Sender: TObject);
  82. var
  83.   I: Integer;
  84. begin
  85.   for I := 0 to SrcList.Items.Count - 1 do
  86.     DstList.Items.AddObject(SrcList.Items[I],
  87.       SrcList.Items.Objects[I]);
  88.   SrcList.Items.Clear;
  89.   SetItem(SrcList, 0);
  90. end;
  91. procedure TfrmPrint.ExcAllBtnClick(Sender: TObject);
  92. var
  93.   I: Integer;
  94. begin
  95.   for I := 0 to DstList.Items.Count - 1 do
  96.     SrcList.Items.AddObject(DstList.Items[I], DstList.Items.Objects[I]);
  97.   DstList.Items.Clear;
  98.   SetItem(DstList, 0);
  99. end;
  100. procedure TfrmPrint.ExAllBtnClick(Sender: TObject);
  101. var
  102.   I: Integer;
  103. begin
  104.   for I := 0 to DstList.Items.Count - 1 do
  105.     SrcList.Items.AddObject(DstList.Items[I], DstList.Items.Objects[I]);
  106.   DstList.Items.Clear;
  107.   SetItem(DstList, 0);
  108. end;
  109. procedure TfrmPrint.DstListDblClick(Sender: TObject);
  110. begin
  111.   excludebtn.click;
  112. end;
  113. procedure TfrmPrint.SrcListDblClick(Sender: TObject);
  114. begin
  115.   includebtn.click;
  116. end;
  117. procedure TfrmPrint.MoveSelected(List: TCustomListBox; Items: TStrings);
  118. var
  119.   I: Integer;
  120. begin
  121.   for I := List.Items.Count - 1 downto 0 do
  122.     if List.Selected[I] then
  123.     begin
  124.       Items.AddObject(List.Items[I], List.Items.Objects[I]);
  125.       List.Items.Delete(I);
  126.     end;
  127. end;
  128. procedure TfrmPrint.SetButtons;
  129. var
  130.   SrcEmpty, DstEmpty: Boolean;
  131. begin
  132.   SrcEmpty := SrcList.Items.Count = 0;
  133.   DstEmpty := DstList.Items.Count = 0;
  134.   IncludeBtn.Enabled := not SrcEmpty;
  135.   IncAllBtn.Enabled := not SrcEmpty;
  136.   ExcludeBtn.Enabled := not DstEmpty;
  137.   ExAllBtn.Enabled := not DstEmpty;
  138. end;
  139. function TfrmPrint.GetFirstSelection(List: TCustomListBox): Integer;
  140. begin
  141.   for Result := 0 to List.Items.Count - 1 do
  142.     if List.Selected[Result] then Exit;
  143.   Result := LB_ERR;
  144. end;
  145. procedure TfrmPrint.SetItem(List: TListBox; Index: Integer);
  146. var
  147.   MaxIndex: Integer;
  148. begin
  149.   with List do
  150.   begin
  151.     SetFocus;
  152.     MaxIndex := List.Items.Count - 1;
  153.     if Index = LB_ERR then Index := 0
  154.     else if Index > MaxIndex then Index := MaxIndex;
  155.     Selected[Index] := True;
  156.   end;
  157.   SetButtons;
  158. end;
  159. //===============================
  160. //当窗体激活的时候
  161. procedure TfrmPrint.FormActivate(Sender: TObject);
  162. begin
  163.   //将当前系统日期赋给edtListDate
  164.   edtListDate.text := formatdatetime('yyyy"年"mm"月"dd"日"', date);
  165.   //将制表人姓名赋给edtLister
  166.   edtLister.text := CurrentParam.userName;
  167.   if srclist.Items.count > 0 then
  168.   begin
  169.     includebtn.Enabled := true;
  170.     IncAllBtn.Enabled := true;
  171.   end;
  172.   if dstlist.Items.count > 0 then
  173.   begin
  174.     ExcludeBtn.Enabled := True;
  175.     ExAllBtn.Enabled := true;
  176.   end;
  177. end;
  178. //获取数据,根据vps_table,vps_filter,vps_index来获取数据。
  179. procedure TfrmPrint.getData;
  180. var
  181.   vs_sql: string;
  182.   Vi: integer;
  183. begin
  184.   //定义SQL语句,到应用服务器端提取数据
  185.   vs_sql := 'select *' + ' from ' + vps_tablename;
  186.   clientdataset.close;
  187.   clientdataset.CommandText := vs_sql;
  188.   //添加过滤条件
  189.   clientdataset.filter := vps_filter;
  190.   clientdataset.filtered := true;
  191.   //定义索引
  192.   clientdataset.IndexFieldNames := vps_index;
  193.   clientDataset.Open;
  194. end;
  195. //将数据导入到EXCEL中
  196. procedure TfrmPrint.ExportDataToExcel;
  197. var
  198.   i, j, k: integer;
  199.   xxx1: string;
  200.   xr: string;
  201. begin
  202.   if frmPrint.dstlist.items.count = 0 then
  203.   begin
  204.     application.messagebox('没有选择目标字段!', '物资管理系统', mb_iconwarning + mb_defbutton1);
  205.     exit;
  206.   end;
  207.   frmPrint.statusbar1.Panels[0].text := '正在载入Excel,请稍候......';
  208.   frmPrint.statusbar1.refresh;
  209.   try
  210.     screen.cursor := crHourGlass;
  211.     try
  212.       //创建EXCEL对象
  213.       varexcel := createoleobject('excel.application');
  214.       if not varisempty(varexcel) then
  215.       begin
  216.         //添加工作簿
  217.         varexcel.workbooks.add;
  218.         varexcel.workbooks[1].worksheets[1].name := '数据库信息';
  219.       end;
  220.     except
  221.       application.messagebox('请确认是否安装Excel?', '提示信息:', mb_iconquestion + mb_defbutton1);
  222.       exit;
  223.     end;
  224.     begin
  225.       //获取数据
  226.       getData;
  227.       //写入列标题
  228.       range := varexcel.workbooks[1].worksheets[1].columns;
  229.       for i := 0 to frmPrint.dstlist.Items.count - 1 do begin
  230.         varexcel.workbooks[1].worksheets[1].cells[2, i + 1].value := frmPrint.dstlist.items.strings[i];
  231.         varexcel.workbooks[1].worksheets[1].cells[2, i + 1].Font.bold := true;
  232.         range.columns[i + 1].columnwidth := frmPrint.clientdataset.Fieldbyname(frmPrint.dstlist.items.Strings[i]).Displaywidth;
  233.         range.columns[I + 1].HorizontalAlignment := xlCenter;
  234.       end;
  235.       try
  236.         try
  237.           //循环写入数据到EXCEL中
  238.           frmPrint.clientdataset.first;
  239.           j := 3;
  240.           while not frmPrint.clientdataset.eof do begin
  241.             for i := 0 to frmPrint.dstlist.Items.count - 1 do begin
  242.               xr := ''''+frmPrint.clientdataset.fieldbyname(frmPrint.dstlist.items.strings[i]).AsString;
  243.               varexcel.workbooks[1].worksheets[1].cells[j, i + 1].value := xr;
  244.             end;
  245.             frmPrint.clientdataset.next;
  246.             j := j + 1;
  247.           end;
  248.           varexcel.workbooks[1].worksheets[1].cells[j + 1, 2].value := '制表: ' + frmPrint.edtLister.text;
  249.           varexcel.workbooks[1].worksheets[1].cells[j + 1, 4].value := '日期: ' + frmPrint.edtListDate.text;
  250.         except
  251.         end;
  252.       finally
  253.         frmPrint.clientdataset.enablecontrols;
  254.         frmPrint.statusbar1.Panels[0].text := '';
  255.         k := i - 1 + ord('A');
  256.         xxx1 := chr(k);
  257.         xxx1 := 'A2:' + xxx1 + inttostr(j - 1);
  258.         //将数据表格画线
  259.         range := varexcel.workbooks[1].worksheets[1].range[xxx1];
  260.         range.borders.linestyle := xlcontinuous;
  261.         k := i - 1 + ord('A');
  262.         xxx1 := chr(k);
  263.         xxx1 := 'a1:' + xxx1 + '1';
  264.         //数据标题列居中
  265.         range := varexcel.workbooks[1].worksheets[1].range[xxx1];
  266.         range.HorizontalAlignment := xlCenter;
  267.         range.VerticalAlignment := xlCenter;
  268.         range.MergeCells := True;
  269.         //对报表标题进行修饰
  270.         varexcel.workbooks[1].worksheets[1].range['a1:a1'] := frmPrint.edtPrintTitle.text;
  271.         varexcel.workbooks[1].worksheets[1].range['a1:a1'].font.name := '楷体';
  272.         varexcel.workbooks[1].worksheets[1].range['a1:a1'].font.size := '18';
  273.         varexcel.workbooks[1].worksheets[1].range['a1:a1'].font.fontstyle := 'bold';
  274.         varexcel.visible := true;
  275.       end;
  276.     end;
  277.   finally
  278.     screen.cursor := crArrow;
  279.   end;
  280. end;
  281. procedure TfrmPrint.btnCancelClick(Sender: TObject);
  282. begin
  283.   close;
  284. end;
  285. procedure TfrmPrint.btnOKClick(Sender: TObject);
  286. begin
  287.   //导入数据到EXCEL
  288.   ExportDataToExcel;
  289. end;
  290. end.