亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? u_general_print.pas

?? 各類企事業(yè)單位的商品、物資、材料的日常庫存管理及財務進銷存核算管理。 ● 全面支持移動加權(quán)平均法、先進先出法、后進先出法計算成本 ● 支持貨品采購、銷售、退貨、領料、...
?? PAS
字號:
unit U_general_print;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  StdCtrls, Buttons, ExtCtrls, ComCtrls, Db, DBClient, variants;

type
  TfrmPrint = class(TForm)
    StatusBar1: TStatusBar;
    Panel1: TPanel;
    SrcLabel: TLabel;
    DstLabel: TLabel;
    IncludeBtn: TSpeedButton;
    IncAllBtn: TSpeedButton;
    ExcludeBtn: TSpeedButton;
    ExAllBtn: TSpeedButton;
    Label2: TLabel;
    Label3: TLabel;
    SrcList: TListBox;
    DstList: TListBox;
    Panel2: TPanel;
    btnOK: TSpeedButton;
    btnCancel: TSpeedButton;
    Panel3: TPanel;
    Label1: TLabel;
    edtPrintTitle: TEdit;
    Panel4: TPanel;
    Label4: TLabel;
    edtLister: TEdit;
    Label5: TLabel;
    edtListDate: TEdit;
    ClientDataSet: TClientDataSet;
    procedure IncludeBtnClick(Sender: TObject);
    procedure ExcludeBtnClick(Sender: TObject);
    procedure IncAllBtnClick(Sender: TObject);
    procedure ExcAllBtnClick(Sender: TObject);
    procedure FormActivate(Sender: TObject);
    procedure ExAllBtnClick(Sender: TObject);
    procedure DstListDblClick(Sender: TObject);
    procedure SrcListDblClick(Sender: TObject);
    procedure btnCancelClick(Sender: TObject);
    procedure btnOKClick(Sender: TObject);
  private
    varexcel: variant; //變體變量,指向創(chuàng)建的EXCEL對象
    range: variant; //變體變量,作為EXCEL一塊區(qū)域的對象
    procedure GetData; //得到數(shù)據(jù)
    procedure ExportDataToExcel; //打印數(shù)據(jù)
    { Private declarations }
  public
    vps_tablename: string; //打印報表的數(shù)據(jù)源的表名稱
    vps_filter: string; //打印報表的數(shù)據(jù)源的表過濾條件
    vps_index: string; //打印報表的數(shù)據(jù)源的索引
    { Public declarations }
    procedure MoveSelected(List: TCustomListBox; Items: TStrings);
    procedure SetItem(List: TListBox; Index: Integer);
    function GetFirstSelection(List: TCustomListBox): Integer;
    procedure SetButtons;
  end;

var
  frmPrint: TfrmPrint;

implementation

uses comobj, excel97, u_public, main;
{$R *.DFM}
//==========================
//操作兩個列表框之間的數(shù)據(jù)移動

procedure TfrmPrint.IncludeBtnClick(Sender: TObject);
var
  Index: Integer;
begin
  Index := GetFirstSelection(SrcList);
  MoveSelected(SrcList, DstList.Items);
  SetItem(SrcList, Index);
end;

procedure TfrmPrint.ExcludeBtnClick(Sender: TObject);
var
  Index: Integer;
begin
  Index := GetFirstSelection(DstList);
  MoveSelected(DstList, SrcList.Items);
  SetItem(DstList, Index);
end;

procedure TfrmPrint.IncAllBtnClick(Sender: TObject);
var
  I: Integer;
begin
  for I := 0 to SrcList.Items.Count - 1 do
    DstList.Items.AddObject(SrcList.Items[I],
      SrcList.Items.Objects[I]);
  SrcList.Items.Clear;
  SetItem(SrcList, 0);
end;

procedure TfrmPrint.ExcAllBtnClick(Sender: TObject);
var
  I: Integer;
begin
  for I := 0 to DstList.Items.Count - 1 do
    SrcList.Items.AddObject(DstList.Items[I], DstList.Items.Objects[I]);
  DstList.Items.Clear;
  SetItem(DstList, 0);
end;

procedure TfrmPrint.ExAllBtnClick(Sender: TObject);
var
  I: Integer;
begin
  for I := 0 to DstList.Items.Count - 1 do
    SrcList.Items.AddObject(DstList.Items[I], DstList.Items.Objects[I]);
  DstList.Items.Clear;
  SetItem(DstList, 0);
end;

procedure TfrmPrint.DstListDblClick(Sender: TObject);
begin
  excludebtn.click;
end;

procedure TfrmPrint.SrcListDblClick(Sender: TObject);
begin
  includebtn.click;
end;

procedure TfrmPrint.MoveSelected(List: TCustomListBox; Items: TStrings);
var
  I: Integer;
begin
  for I := List.Items.Count - 1 downto 0 do
    if List.Selected[I] then
    begin
      Items.AddObject(List.Items[I], List.Items.Objects[I]);
      List.Items.Delete(I);
    end;
end;

procedure TfrmPrint.SetButtons;
var
  SrcEmpty, DstEmpty: Boolean;
begin
  SrcEmpty := SrcList.Items.Count = 0;
  DstEmpty := DstList.Items.Count = 0;
  IncludeBtn.Enabled := not SrcEmpty;
  IncAllBtn.Enabled := not SrcEmpty;
  ExcludeBtn.Enabled := not DstEmpty;
  ExAllBtn.Enabled := not DstEmpty;
end;

function TfrmPrint.GetFirstSelection(List: TCustomListBox): Integer;
begin
  for Result := 0 to List.Items.Count - 1 do
    if List.Selected[Result] then Exit;
  Result := LB_ERR;
end;

procedure TfrmPrint.SetItem(List: TListBox; Index: Integer);
var
  MaxIndex: Integer;
begin
  with List do
  begin
    SetFocus;
    MaxIndex := List.Items.Count - 1;
    if Index = LB_ERR then Index := 0
    else if Index > MaxIndex then Index := MaxIndex;
    Selected[Index] := True;
  end;
  SetButtons;
end;

//===============================

//當窗體激活的時候

procedure TfrmPrint.FormActivate(Sender: TObject);
begin
  //將當前系統(tǒng)日期賦給edtListDate
  edtListDate.text := formatdatetime('yyyy"年"mm"月"dd"日"', date);
  //將制表人姓名賦給edtLister
  edtLister.text := CurrentParam.userName;
  if srclist.Items.count > 0 then
  begin
    includebtn.Enabled := true;
    IncAllBtn.Enabled := true;
  end;
  if dstlist.Items.count > 0 then
  begin
    ExcludeBtn.Enabled := True;
    ExAllBtn.Enabled := true;
  end;
end;

//獲取數(shù)據(jù),根據(jù)vps_table,vps_filter,vps_index來獲取數(shù)據(jù)。

procedure TfrmPrint.getData;
var
  vs_sql: string;
  Vi: integer;
begin
  //定義SQL語句,到應用服務器端提取數(shù)據(jù)
  vs_sql := 'select *' + ' from ' + vps_tablename;
  clientdataset.close;
  clientdataset.CommandText := vs_sql;
  //添加過濾條件
  clientdataset.filter := vps_filter;
  clientdataset.filtered := true;
  //定義索引
  clientdataset.IndexFieldNames := vps_index;
  clientDataset.Open;
end;

//將數(shù)據(jù)導入到EXCEL中

procedure TfrmPrint.ExportDataToExcel;
var
  i, j, k: integer;
  xxx1: string;
  xr: string;
begin
  if frmPrint.dstlist.items.count = 0 then
  begin
    application.messagebox('沒有選擇目標字段!', '物資管理系統(tǒng)', mb_iconwarning + mb_defbutton1);
    exit;
  end;
  frmPrint.statusbar1.Panels[0].text := '正在載入Excel,請稍候......';
  frmPrint.statusbar1.refresh;
  try
    screen.cursor := crHourGlass;
    try
      //創(chuàng)建EXCEL對象
      varexcel := createoleobject('excel.application');
      if not varisempty(varexcel) then
      begin
        //添加工作簿
        varexcel.workbooks.add;
        varexcel.workbooks[1].worksheets[1].name := '數(shù)據(jù)庫信息';
      end;
    except
      application.messagebox('請確認是否安裝Excel?', '提示信息:', mb_iconquestion + mb_defbutton1);
      exit;
    end;
    begin
      //獲取數(shù)據(jù)
      getData;
      //寫入列標題
      range := varexcel.workbooks[1].worksheets[1].columns;
      for i := 0 to frmPrint.dstlist.Items.count - 1 do begin
        varexcel.workbooks[1].worksheets[1].cells[2, i + 1].value := frmPrint.dstlist.items.strings[i];
        varexcel.workbooks[1].worksheets[1].cells[2, i + 1].Font.bold := true;
        range.columns[i + 1].columnwidth := frmPrint.clientdataset.Fieldbyname(frmPrint.dstlist.items.Strings[i]).Displaywidth;
        range.columns[I + 1].HorizontalAlignment := xlCenter;
      end;
      try
        try
          //循環(huán)寫入數(shù)據(jù)到EXCEL中
          frmPrint.clientdataset.first;
          j := 3;
          while not frmPrint.clientdataset.eof do begin
            for i := 0 to frmPrint.dstlist.Items.count - 1 do begin
              xr := ''''+frmPrint.clientdataset.fieldbyname(frmPrint.dstlist.items.strings[i]).AsString;
              varexcel.workbooks[1].worksheets[1].cells[j, i + 1].value := xr;
            end;
            frmPrint.clientdataset.next;
            j := j + 1;
          end;
          varexcel.workbooks[1].worksheets[1].cells[j + 1, 2].value := '制表: ' + frmPrint.edtLister.text;
          varexcel.workbooks[1].worksheets[1].cells[j + 1, 4].value := '日期: ' + frmPrint.edtListDate.text;
        except
        end;
      finally
        frmPrint.clientdataset.enablecontrols;
        frmPrint.statusbar1.Panels[0].text := '';
        k := i - 1 + ord('A');
        xxx1 := chr(k);
        xxx1 := 'A2:' + xxx1 + inttostr(j - 1);
        //將數(shù)據(jù)表格畫線
        range := varexcel.workbooks[1].worksheets[1].range[xxx1];
        range.borders.linestyle := xlcontinuous;
        k := i - 1 + ord('A');
        xxx1 := chr(k);
        xxx1 := 'a1:' + xxx1 + '1';
        //數(shù)據(jù)標題列居中
        range := varexcel.workbooks[1].worksheets[1].range[xxx1];
        range.HorizontalAlignment := xlCenter;
        range.VerticalAlignment := xlCenter;
        range.MergeCells := True;
        //對報表標題進行修飾
        varexcel.workbooks[1].worksheets[1].range['a1:a1'] := frmPrint.edtPrintTitle.text;
        varexcel.workbooks[1].worksheets[1].range['a1:a1'].font.name := '楷體';
        varexcel.workbooks[1].worksheets[1].range['a1:a1'].font.size := '18';
        varexcel.workbooks[1].worksheets[1].range['a1:a1'].font.fontstyle := 'bold';
        varexcel.visible := true;
      end;
    end;
  finally
    screen.cursor := crArrow;
  end;
end;

procedure TfrmPrint.btnCancelClick(Sender: TObject);
begin
  close;
end;


procedure TfrmPrint.btnOKClick(Sender: TObject);
begin
  //導入數(shù)據(jù)到EXCEL
  ExportDataToExcel;
end;
end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美三级韩国三级日本一级| 一本大道av伊人久久综合| 国产一区二区在线观看视频| 色悠悠亚洲一区二区| 精品久久久久久久一区二区蜜臀| 一区二区三区资源| 国产成人精品综合在线观看| 制服丝袜av成人在线看| 亚洲色图清纯唯美| 粉嫩av一区二区三区| 欧美大片在线观看一区二区| 亚洲一二三四在线观看| 国产超碰在线一区| 精品国产亚洲在线| 奇米一区二区三区av| 精品1区2区3区| 亚洲激情六月丁香| 99精品视频一区二区三区| 精品久久久久久久久久久久包黑料 | 亚洲国产欧美另类丝袜| 成人av一区二区三区| 久久夜色精品国产欧美乱极品| 日韩精品乱码免费| 欧美性大战久久久久久久蜜臀 | 国产一区二区不卡在线| 在线不卡一区二区| 午夜精品久久久久久久99水蜜桃| 色欧美日韩亚洲| 亚洲精品国产第一综合99久久 | 蜜臀av一区二区| 在线电影院国产精品| 天堂av在线一区| 3d动漫精品啪啪| 日韩二区三区四区| 欧美一区二区在线播放| 秋霞电影一区二区| 91精品国产综合久久久久久| 日韩国产欧美一区二区三区| 欧美二区乱c少妇| 秋霞成人午夜伦在线观看| 欧美成人女星排名| 日韩一区二区三免费高清| 亚洲mv在线观看| 欧美日本一区二区在线观看| 日本在线播放一区二区三区| 日韩欧美国产高清| 国产乱理伦片在线观看夜一区| 国产午夜一区二区三区| av激情成人网| 亚洲大片免费看| 日韩一区二区麻豆国产| 国产乱色国产精品免费视频| 国产精品久久三| 欧美午夜精品久久久久久超碰| 日日夜夜免费精品| 亚洲精品一区二区三区在线观看 | 亚洲综合免费观看高清在线观看| 欧美亚州韩日在线看免费版国语版| 亚洲国产毛片aaaaa无费看| 日韩午夜在线观看视频| 国产激情视频一区二区在线观看| 亚洲欧美在线观看| 欧美高清视频不卡网| 国产呦精品一区二区三区网站| 中文字幕亚洲成人| 欧美喷水一区二区| 国产乱码精品一区二区三区av | 首页国产丝袜综合| 久久午夜色播影院免费高清| 91视频免费播放| 日本欧美大码aⅴ在线播放| 国产精品网站在线观看| 欧美日韩精品欧美日韩精品一综合| 九一久久久久久| 亚洲老妇xxxxxx| 久久久国产午夜精品| 欧美影院一区二区| 国产精品1区2区| 午夜精品福利久久久| 国产精品久久久久久户外露出 | 丝袜亚洲另类欧美| 国产欧美综合在线| 欧美一级理论片| 91女厕偷拍女厕偷拍高清| 精品一区二区三区在线播放视频| 亚洲精品欧美激情| 亚洲国产激情av| 精品国产一区二区三区不卡 | 国产精品动漫网站| 91精品国产高清一区二区三区| 99久久伊人网影院| 国产在线精品国自产拍免费| 午夜精品福利一区二区蜜股av | www成人在线观看| 欧美午夜一区二区三区| 99这里只有久久精品视频| 国产综合久久久久影院| 无吗不卡中文字幕| 亚洲一卡二卡三卡四卡五卡| 国产精品不卡视频| 国产视频不卡一区| 久久香蕉国产线看观看99| 91精品国产综合久久小美女 | 丁香婷婷综合色啪| 精品一区二区三区在线视频| 免费人成在线不卡| 日本一不卡视频| 日韩精品色哟哟| 亚洲成人精品影院| 午夜欧美一区二区三区在线播放| 亚洲美女一区二区三区| 亚洲欧美一区二区三区国产精品| 国产精品三级av在线播放| 国产偷国产偷精品高清尤物| 久久免费美女视频| 国产丝袜在线精品| 中文在线一区二区 | 日韩欧美国产一区二区在线播放| 欧美一区二区三区四区视频| 欧美一区二区三区思思人| 欧美人狂配大交3d怪物一区| 欧美精品丝袜久久久中文字幕| 精品视频色一区| 欧美精品三级日韩久久| 欧美一级理论片| 精品99999| 国产精品视频线看| 亚洲女人小视频在线观看| 亚洲精品国产一区二区三区四区在线| 亚洲精品日韩一| 午夜精品久久久久久久久 | 一区二区日韩电影| 亚洲国产精品久久一线不卡| 午夜电影一区二区| 国内成+人亚洲+欧美+综合在线| 国内久久精品视频| av在线这里只有精品| 欧美日韩综合在线免费观看| 91精品国产高清一区二区三区| 久久综合资源网| 亚洲欧美综合另类在线卡通| 亚洲国产精品久久久久婷婷884| 日韩精品乱码免费| 国产成人精品网址| 色悠悠久久综合| 日韩视频一区二区在线观看| 久久久不卡网国产精品一区| 亚洲欧美区自拍先锋| 美女一区二区三区| 91影院在线观看| 日韩欧美中文字幕公布| 国产精品美女久久久久av爽李琼| 午夜婷婷国产麻豆精品| 国产精品2024| 这里只有精品99re| 国产精品不卡视频| 视频一区视频二区中文| 波多野结衣精品在线| 6080日韩午夜伦伦午夜伦| 欧美国产丝袜视频| 视频一区视频二区中文字幕| 成人高清视频免费观看| 日韩一级片网站| 一区二区三区四区高清精品免费观看| 久久se精品一区二区| 日本久久电影网| 国产欧美日韩在线视频| 日韩国产成人精品| 91在线视频免费观看| 2023国产精品自拍| 日日夜夜免费精品| 色婷婷激情综合| 亚洲国产精品成人综合| 麻豆专区一区二区三区四区五区| 色综合天天综合网天天看片| 久久精品夜色噜噜亚洲a∨| 日本午夜精品一区二区三区电影| 91麻豆免费视频| 国产精品三级久久久久三级| 狠狠色伊人亚洲综合成人| 欧美日韩精品三区| 亚洲自拍偷拍网站| av不卡免费电影| 国产精品欧美经典| 国产毛片精品一区| 精品国产91久久久久久久妲己| 亚洲福利视频一区| 91福利视频网站| 一区二区成人在线视频| 99综合电影在线视频| 亚洲国产成人在线| 国产suv精品一区二区6| 2023国产精品| 国产精品69毛片高清亚洲| 精品99一区二区| 国产精品白丝av| 欧美国产日韩在线观看| 成人在线视频首页| 中文字幕一区二区三区视频| 粉嫩aⅴ一区二区三区四区|