::: 델파이 Tip&Trick :::

델파이 Tip&Trick 성격에 맞지 않는 광고,비방,질문의 글은 즉시 삭제하며
내용을 복사하여 사용할 경우 반드시 이곳(http://www.howto.pe.kr)을 출처로 명시하여 주세요


Category

  김영대(2003-03-06 22:02:24, Hit : 5948, Vote : 1300
 Save DBGrid To Excel

function SaveDBGridToExcel(dbgrd: TDBGrid): Boolean ;
{
  SaveDBGridToExcel.
  Saves the data related to the database grid to an Excel spreadsheet.
  Arguments: dbgrd - TDBGrid
}
var
  intRow, // index for query rows
  intCol : Integer ; // index for query columns
  ExcelApp, // Excel application
  WorkBook, // Excel workbook
  WorkSheet : Variant ; // Excel sheet in workbook
  qry : TQuery ; // Query related to dbgrd
  BookMark : TBookMark ; // Bookmark for query
  SaveDialog : TSaveDialog ;
begin
  // Initialize
  ExcelApp := Unassigned ;
  SaveDialog := nil ;
  qry := nil ;
  BookMark := nil ;
  Result := False ;

  try
    // Dereference database grid to get datasource and supplying query
    qry := TQuery(TDataSource(dbgrd.DataSource).DataSet) ;

    // If the query is inactive or record count < 1 then outta here
    if qry.Active = False then
      exit ;
    if qry.RecordCount < 1 then
      exit ;

    // Create save dialog and set it options
    SaveDialog := TSaveDialog.Create(dbgrd.Parent) ;
    with SaveDialog do
    begin
      DefaultExt := 'xls' ;
      Filter := 'Excel files (*.xls)|*.xls|All files (*.*)|*.*' ;
      Options := [ofOverwritePrompt,ofPathMustExist,ofNoReadOnlyReturn,ofHideReadOnly] ;
      Title := 'Specify Excel file to which to save the grid information';
    end ;

    // Execute save dialog
    if SaveDialog.Execute then
    begin
      SEIApp.SetBusy(True) ;

      // Delete entered filename if it exists
      If FileExists(SaveDialog.FileName) then
        DeleteFile(SaveDialog.FileName) ;

      // Create instance of Excel
      try
        ExcelApp := CreateOLEObject('Excel.Application') ;
      except
        MessageDLG('Unable to start Excel',mtError,[mbOK],0) ;
        Raise ;
      end ;

      {$IFDEF IAMDEBUGGING}
      ExcelApp.Visible := True ;
      {$ENDIF}

      // Create Excel workbook
      ExcelApp.WorkBooks.Add ;

      // Get the active workbook
      WorkBook := ExcelApp.ActiveWorkBook ;

      // Get the active sheet
      WorkSheet := WorkBook.ActiveSheet ;

      // Insert column headers into sheet
      intRow := 1 ;
      for intCol := 1 to qry.FieldCount do
        WorkSheet.Cells[intRow,intCol].Value := qry.Fields[intCol-1].FieldName ;

      // Disable controls attached to query
      qry.DisableControls ;

      // Save place in query
      BookMark := qry.GetBookmark ;

      // Position to first row
      qry.First ;

      // Insert data into sheet
      while (not qry.EOF) do
      begin
        SEIApp.SetBusy(True) ;

        inc(intRow) ;
        for intCol := 1 to qry.FieldCount do
        begin
          WorkSheet.Cells[intRow,intCol].Value := qry.Fields[intCol-1].AsString ;
        end ;

        qry.Next ;
      end ;

      SEIApp.SetBusy(True) ;

      // Restore position in query
      qry.GotoBookmark(BookMark) ;

      // Free bookmark
      qry.FreeBookmark(BookMark) ;

      // Enable controls attached to query
      qry.EnableControls ;

      // Save Excel spreadsheet
      WorkBook.SaveAs(SaveDialog.FileName) ;
      WorkBook.Close ;

      // Quit excel
      ExcelApp.Quit ;

      // Function result is OK
      Result := True ;

      // Status user
      ShowMessage('Completed save to '+SaveDialog.FileName) ;
    end ;

    // Free save dialog
    SaveDialog.Free ;

    SEIApp.SetBusy(False) ;

  except on E:Exception do // Exceptions
    begin
      // If Excel was started, quit it.
      if (ExcelApp <> Unassigned) then
        ExcelApp.Quit ;

      if SaveDialog <> nil then
        SaveDialog.Free ;

      // Restore position in query and enable controls
      if BookMark <> nil then
      begin
        qry.GoToBookMark(BookMark) ;
        qry.FreeBookMark(BookMark) ;
        qry.EnableControls ;
      end ;

      SEIApp.SetBusy(False) ;

      // Status user
      MessageDLG('(SaveDBGridAsExcel) exception: '+E.Message, mtError,[mbOK],0) ;

      // Reraise exception
      raise;
    end;
  end; {try}
end;





571   [시스템] 마이크 볼륨 조절하기  김영대 2003/03/06 4332 1219
570   [멀티미디어] JPEG, WAVE 를 resource 파일에 넣고 읽어오기  김영대 2003/03/06 4818 1161
569   [일반/컴포넌트] desktop 배경화면을 폼의 배경화면으로 그리기  김영대 2003/03/06 3381 977
568   [윈도우즈 API] 레지스트리의 변경여부 알리는 2가지 방법  김영대 2003/03/06 4445 1162
567   [일반/컴포넌트] StringGrid 의 내용을 클립보드로 복사하기  김영대 2003/03/06 4165 1007
  [데이터베이스] Save DBGrid To Excel  김영대 2003/03/06 5948 1300
565   [COM/OLE] Delphi의 OCX를 InstallShield로 배포하는 방법  김영대 2003/03/06 6261 1549
564   [일반/컴포넌트] ASCII printing  김영대 2003/03/06 4673 1137
563   [일반/컴포넌트] OEM conversion  김영대 2003/03/06 4071 1205
562   [일반/컴포넌트] Memo의 행의 문자수를 제한하고 WordWrap시키기  김영대 2003/03/06 4752 1258
561   [윈도우즈 API] DDE 쓰지 않고 IE의 현재 URL 가져오기  김영대 2003/03/06 5687 1589
560   [윈도우즈 API] RichEdit에 입력한 문장의 실제 높이 구하기  김영대 2003/03/06 4761 1374
559   [일반/컴포넌트] StringGrid 의 선택영역만 클립보드로 복사하기  김영대 2003/03/06 4469 975
558   [일반/컴포넌트] StringGrid 에서 프로그램으로 MultiSelect 시키기  김영대 2003/03/06 4877 1122
557   [윈도우즈 API] 윈도우즈 '시작' 메뉴 Refresh 시키기  김영대 2003/03/07 4384 1362
556   [윈도우즈 API] 다른 Application의 화면에 글자,그림을 출력하기  김영대 2003/03/07 3130 804
555   [일반/컴포넌트] WideString 을 String 으로 바꾸기  김영대 2003/03/07 4226 1004
554   [윈도우즈 API] 윈도우즈 탐색기의 파일, 컴퓨터 찾기 화면 띄우기  김영대 2003/03/07 5875 1571
553   [일반/컴포넌트] MessageDlg()의 폰트를 바꾸어서 띄우기  김영대 2003/03/07 3590 967
552   [일반/컴포넌트] ListView 의 item 을 강제로 편집상태로 만들기  김영대 2003/03/07 4333 1113
551   [데이터베이스] 동적으로 SELECT의 GROUP BY 문 만들기  김영대 2003/03/07 3949 886
550   [윈도우즈 API] ALT_F4 hot key 가로채기  김영대 2003/03/07 5372 1547
549   [윈도우즈 API] 레지스트리 전체 검색하기  김영대 2003/03/07 3930 1079
548   [일반/컴포넌트] TOpenDialog 의 '선택','취소' 버튼 이름 바꾸기  김영대 2003/03/07 4150 1286
547   [윈도우즈 API] 모서리가 둥근(rounded ends) TEdit 만들기  김영대 2003/03/07 4368 1231
546   [시스템] 프로그램이 동적으로 할당받은 메모리 크기 ?  김영대 2003/03/07 4250 1234
545   [일반/컴포넌트] OnActivate 이벤트 내에서 폼 확실히 닫기  김영대 2003/03/07 4006 1035
544   [데이터베이스] Query한 결과를 수정하기...  김영대 2003/03/07 4653 1151
543   [일반/컴포넌트] StringGrid의 Cell을 강제로 다중 선택/해제 시키기  김영대 2003/03/07 3747 958
542   [일반/컴포넌트] TRichEdit의 행간격 띄우기(line spacing)  김영대 2003/03/07 5202 1435
541   [일반/컴포넌트] 프린터로 escape 문자 출력하기(raw print)  김영대 2003/03/07 4574 1091
540   [윈도우즈 API] keyboard, mouse 메시지 무시(skip) 하기  김영대 2003/03/07 4168 1152
539   [윈도우즈 API] 윈도우즈 커서(global cursor) 바꾸기  김영대 2003/03/07 6535 2020
538   [시스템] 현재 프린터의 출력가능한 용지종류 구하기  김영대 2003/03/07 5961 1592
537   [시스템] 프린터에 작업중인 job의 리스트 구하기  김영대 2003/03/07 4493 1183
536   [시스템] Clipboard 훔쳐보기(Clipboard hooking)  김영대 2003/03/07 6523 1525
535   [윈도우즈 API] Control의 repainting 금지하여 깜박임 줄이기  김영대 2003/03/07 4924 1187
534   [일반/컴포넌트] 문자열의 끝에서부터 검색하는 Pos() 함수  김영대 2003/03/07 4909 1118
533   [일반/컴포넌트] 디렉토리명 바꾸기/이동 하기  김영대 2003/03/07 4997 1513
532   [일반/컴포넌트] 디렉토리 변동사항을 탐색기에 알리기  김영대 2003/03/07 5008 1532

[이전 10개] [1].. 11 [12][13][14][15][16][17][18][19][20]..[25] [다음 10개]
 

Copyright 1999-2019 Zeroboard / skin by zero