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

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


Category

  김영대(2003-03-06 21:19:57, Hit : 6843, Vote : 1592
 Excel ODBC를 사용하여 xls를 테이블로 사용하기

각 단계별로 아래 순서대로 설정하시면 됩니다


[1]. Excel ODBC Driver 설정과 Alias 만들기

a.델파이에 있는 'BDE Administrator' 를 실행한다

b.'BDE Administrator'의 화면 좌측에 있는 'Database' 창에서
   마우스의 오른쪽을 클릭하여 'ODBC Administrator...'을 선택합니다

c.'ODBC 데이터 원본 관리자' 프로그램이 실행되면 두번째 탭의 '사용자 DSN'
   을 선택합니다 (DSN = ODBC Data Source Name)
   오른쪽의 '추가' 버튼을 클릭하여 새 시스템 데이터 원본(DSN)을 추가합니다

d.새 데이터 원본 작성 대화 상자가 드라이버 목록과 함께 나타납니다.
   'Microsoft Excel Dirver (*.xls)' 를 선택한 후 '마침' 버튼을 누르면
   'ODBC Microsoft Excel 설정' 화면이 나타납니다

e.'데이터 원본 이름' 항목에 alias 를 넣으시면 되는데 명칭은 임으로 만드시면 됩니다
   설명상 MyExcel 로 넣겠습니다
   '버전(V)' 항목에는 현재 사용중인 Excel의 버전을 선택하시면 됩니다
   '통합문서 선택' 버튼을 클릭해서 DataBase로 사용할 xls 파일 하나를 선택하고
   '확인' 버튼을 클릭하세요
       참고: Excel ODBC 를 사용하여 Excel 파일을 테이블처럼 사용하시려면
             xls 파일 하나를 DataBase 로 보시고 xls 파일에 들어있는 sheet 들을
             table로 생각하시면 됩니다.

f. '옵션(O)>>' 버튼을 클릭해서 '읽기전용'이 체크되지 않도록 합니다
    옵션을 설정한후 '확인' 버튼을 누르면 '사용자 DSN' 에 방금 만든
    'MyExcel Microsoft Excel Driver (*.xls)' DSN 하나가 만들어져 있을 겁니다

g. 지금까지는 사용자 DSN(여기서는 MyExcel) 을 만들었습니다
    사용자 DSN 의 데이터 원본은 지정한 컴퓨터에만 영향을 미치며 현재 사용자만
    사용할 수 있습니다.

    그외에도 '시스템 DSN', '파일 DSN' 등등이 있는데 이건 해당 화면에서
    ODBC 도움말을 참고하시면 되고 설정방법은 비슷합니다
    참고로 '시스템 DSN'의 데이터 원본은 사용자보다 지역 컴퓨터의 영향을 받습니다.
    권한이 있는 사용자나 시스템은 시스템 DSN으로 설정한 데이터 원본을 사용할 수 있습니다.

h. 처음 'BDE Administrator'의 화면 좌측에 있는 'Database' 창을 보시면
    좀전에 만든 MyExcel 이라는 alias 하나가 만들어져 있을 겁니다
    더블클릭 해보시면 username 과 password 를 물어보는데 그냥 'Ok' 버튼을 누루세요


[2]. 프로그램에서 사용하기

a.델파이를 실행해서 새 어플리케이션을 만듭니다

b.폼위에 TDataBase, TTable, TDataSource, TDBGrid 를 각각 하나씩 올려놓습니다
   TDataBase 를 더블클릭하고 'Name' 에 ExcelDB 라 입력하고
   'Alias name'의 콤보박스를 누르면 'MyExcel' 이라는 좀전에 만든 alias 가
   올라와 있으니 선택하세요
   'Defaults' 버튼을 눌러서 기본 정보를 가지고 옵니다
   화면 하단의 'Login prompt' 를 체크하지 않은 상태로 만들고 'Ok' 버튼을
   누르세요

c.TTable의 DatabaseName 을 좀전에 입력한 ExcelDB 라고 입력 또는 선택하세요
   그리고 TTable의 TableName 에는 위에서 설명한데로 지정한 xls 파일의
   sheet 이름을 입력해야 합니다 (리스트로 나타나지 않고 직접 입력해야 합니다)
   만약 xls 파일에 Sheet1 이라는 sheet가 있었다면 명칭은 뒤에 $ 문자를 하나
   추가해서 Sheet1$ 라고 입력하세요

d. 나머지 작업은 일반 Table 작업과 동일합니다






611   [데이터베이스] DB에 저장된 JPEG(JPG)를 DBGrid에 출력하기  김영대 2003/03/06 5232 1252
610   [데이터베이스] 동적으로 인덱스 만들기  김영대 2003/03/06 4455 1128
  [데이터베이스] Excel ODBC를 사용하여 xls를 테이블로 사용하기  김영대 2003/03/06 6843 1592
608   [데이터베이스] DB alias중 ORACLE alias 명 구하기  김영대 2003/03/06 4000 971
607   [일반/컴포넌트] QuickReport에서 프린터 바꾸어서 출력하기  김영대 2003/03/06 6215 1540
606   [일반/컴포넌트] RichEdit 의 내용을 Bitmap 으로 만들기  김영대 2003/03/06 3341 870
605   [일반/컴포넌트] RichEdit 에서 문자(열)를 찾아 글자속성 바꾸기  김영대 2003/03/06 4727 1212
604   [일반/컴포넌트] RichEdit 에서 커서를 처음, 마지막으로 보내기  김영대 2003/03/06 6868 1474
603   [윈도우즈 API] 실행중인 모든 프로그램 Minimized 시키기  김영대 2003/03/06 4647 1231
602   [시스템] 델파이로 DOS 프로그램(Console application) 만들기  김영대 2003/03/06 17031 7521
601   [COM/OLE] Registering *.tlb files without Delphi  김영대 2003/03/06 4981 1129
600   [네트웍/인터넷] How to bring a network down - "Win Nuke"  김영대 2003/03/06 7286 1991
599   [윈도우즈 API] 폴더나 파일의 윈도우즈 등록정보 dialog 띄우기  김영대 2003/03/06 5085 1473
598   [일반/컴포넌트] 이미지를 마우스로 drag 해서 zoom 하기  김영대 2003/03/06 3599 1023
597   [윈도우즈 API] 외부 프로그램을 최상위로 설정하기  김영대 2003/03/06 5213 1232
596   [일반/컴포넌트] TObject의 프로퍼티를 문자열로 참조하기  김영대 2003/03/06 5216 1591
595   [윈도우즈 API] 프로그램으로 Screensaver 등록하는 두가지 방법  김영대 2003/03/06 4479 1267
594   [데이터베이스] 특정 폼의 현재 편집중인 DB Field 구하기  김영대 2003/03/06 4082 1110
593   [윈도우즈 API] KeyDown의 Beep음을 없애자...  김영대 2003/03/06 4614 1210
592   [시스템] How do I use SetWindowsHookEx ?  김영대 2003/03/06 6803 954
591   [시스템] Redirecting DOS Application Output  김영대 2003/03/06 4492 1207
590   [일반/컴포넌트] 두개의 RichEdit 사이에 내용 복사하기  김영대 2003/03/06 5844 1364
589   [일반/컴포넌트] 특정 Color의 Invert Color 구하기  김영대 2003/03/06 4308 1315
588   [일반/컴포넌트] 문자열 수식문장(expression)의 결과 구하기  김영대 2003/03/06 3331 873
587   [시스템] 오디오 CD의 볼륨 조절하기  김영대 2003/03/06 3601 1025
586   [일반/컴포넌트] 윈도우즈 "날짜/시간" 설정화면 띄우기  김영대 2003/03/06 6194 1822
585   [시스템] 마이크 볼륨 조절하기  김영대 2003/03/06 4630 1284
584   [멀티미디어] JPEG, WAVE 를 resource 파일에 넣고 읽어오기  김영대 2003/03/06 5238 1223
583   [일반/컴포넌트] desktop 배경화면을 폼의 배경화면으로 그리기  김영대 2003/03/06 3668 1037
582   [윈도우즈 API] 레지스트리의 변경여부 알리는 2가지 방법  김영대 2003/03/06 4750 1279
581   [일반/컴포넌트] StringGrid 의 내용을 클립보드로 복사하기  김영대 2003/03/06 4454 1060
580   [데이터베이스] Save DBGrid To Excel  김영대 2003/03/06 6964 1797
579   [COM/OLE] Delphi의 OCX를 InstallShield로 배포하는 방법  김영대 2003/03/06 6753 5616
578   [일반/컴포넌트] ASCII printing  김영대 2003/03/06 5271 1211
577   [일반/컴포넌트] OEM conversion  김영대 2003/03/06 4310 1262
576   [일반/컴포넌트] Memo의 행의 문자수를 제한하고 WordWrap시키기  김영대 2003/03/06 5218 1314
575   [윈도우즈 API] DDE 쓰지 않고 IE의 현재 URL 가져오기  김영대 2003/03/06 5976 1673
574   [윈도우즈 API] RichEdit에 입력한 문장의 실제 높이 구하기  김영대 2003/03/06 5027 1426
573   [일반/컴포넌트] StringGrid 의 선택영역만 클립보드로 복사하기  김영대 2003/03/06 4840 1075
572   [일반/컴포넌트] StringGrid 에서 프로그램으로 MultiSelect 시키기  김영대 2003/03/06 5387 1187

[1][2][3][4][5][6][7][8][9] 10 ..[25] [다음 10개]
 

Copyright 1999-2022 Zeroboard / skin by zero