C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[72668] 엑셀파일을 불러서 값 몇개를 변경한후 저장을 하려합니다.
도치 [always97] 3934 읽음    2015-05-21 15:11
예전에도 사용했던 코드인데 , 갑자기 에러가 발생하면서 수행이 되지 않습니다.

컴파일시 에러가 아니라 실행할때 에러가 납니다.

에러의 위치는 경고창에서는 get_Item((TVariant)1)); 이부분에서 뜬다고 나오는데..

get_Item((TVariant)"Sheet1")); 으로 변경해봐도 동일합니다.

컴파일환경은 6.0 에서 하고있습니다.  혹시나 비슷한 문제 겪으신분 계실까요 ?

  char  szCurPath[1024],szOrgFile[1024],szBuffer[1024];
  WideString  OrgFileName,ChkSheet = "Sheet1";

  strcpy(szOrgFile,ExtractFilePath(Application->ExeName).c_str());
  strcat(szOrgFile,"ResultFormat03.xlsx");
  OrgFileName = szOrgFile;
  try {

    try {
      ExcelApplication1->Connect();
      ExcelApplication1->set_Visible(TDefLCID(),false);
    } catch(...) {
      MessageDlg("엑셀프로그램이 설치되지 않았습니다.", mtError, TMsgDlgButtons() << mbOK, 0);
//      delete OXLApp;
//      OXLApp = 0;
      return;
    }
    try {
      if (FileExists(szOrgFile)) {
        ExcelWorkbook1->ConnectTo(ExcelApplication1->Workbooks->Open(OrgFileName));
        ExcelWorksheet1->ConnectTo(ExcelWorkbook1->Worksheets->get_Item((TVariant)1));

// 여기에서 값을 수정하고 있습니다.

        ExcelWorksheet1->SaveAs(TVariant(szFileName));
        ExcelWorkbook1->Close(TVariant(true), TNoParam(), TNoParam(), LCID);
      }
    } __finally {
      ExcelWorksheet1->Disconnect();  // Important: must release ptr
      ExcelWorkbook1->Disconnect();
      ExcelApplication1->Disconnect(); // Use disconnect for SERVER COMPONENT
      ExcelApplication1->Quit();
    }
  }catch(...) {
  }

+ -

관련 글 리스트
72668 엑셀파일을 불러서 값 몇개를 변경한후 저장을 하려합니다. 도치 3934 2015/05/21
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.