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
[11699] [질문] 엑셀파일로 저장하는 델파이 코드를 C++Builder 코드로..
이의태 [] 1496 읽음    2001-10-10 19:14
안녕하세요. 다음 코드는 델파이에서 엑셀프로그램 없이 직접 엑셀파일을 만들고 기록하는 코드입니다.
이 코드를 C++Builder에서 사용할려고 변환해보니 잘 안됩니다. 파스칼 실력이 없어서 그렇습니다.
이 코드를 C++Builder에서 사용하려면 어떻게 고치면 되는지요? 이것을 해결하지 못하면 델파이로 다시 돌아가는 수 밖에 없습니다.

고수님들의 답변을 부탁드립니다.

const
  CXlsBof: array[0..5] of Word = ($809, 8, 00, $10, 0, 0);
  CXlsEof: array[0..1] of Word = ($0A, 00);
  CXlsLabel: array[0..5] of Word = ($204, 0, 0, 0, 0, 0);
  CXlsNumber: array[0..4] of Word = ($203, 14, 0, 0, 0);
  CXlsRk: array[0..4] of Word = ($27E, 10, 0, 0, 0);

var
  Form1: TForm1;

implementation

{$R *.DFM}

procedure XlsBeginStream(XlsStream: TStream; const BuildNumber: word);
begin
  CXlsBof[4] := BuildNumber;
  XlsStream.WriteBuffer(CXlsBof, SizeOf(CXlsBof));
end;

procedure XlsEndStream(XlsStream: TStream);
begin
  XlsStream.WriteBuffer(CXlsEof, SizeOf(CXlsEof));
end;

procedure XlsWriteCellRk(XlsStream: TStream; const ACol, ARow: Word; const AValue: Integer);
var
  V: Integer;
begin
  CXlsRk[2] := ARow;
  CXlsRk[3] := ACol;
  XlsStream.WriteBuffer(CXlsRk, SizeOf(CXlsRk));
  V := (AValue shl 2) or 2;
  XlsStream.WriteBuffer(V, 4);
end;

procedure XlsWriteCellNumber(XlsStream: TStream; const ACol, ARow: Word; const AValue: Double);
begin
  CXlsNumber[2] := ARow;
  CXlsNumber[3] := ACol;
  XlsStream.WriteBuffer(CXlsNumber, SizeOf(CXlsNumber));
  XlsStream.WriteBuffer(AValue, 8);
end;

procedure XlsWriteCellLabel(XlsStream: TStream; const ACol, ARow: Word; const AValue: string);
var
  L: Word;
begin
  L := Length(AValue);
  CXlsLabel[1] := 8 + L;
  CXlsLabel[2] := ARow;
  CXlsLabel[3] := ACol;
  CXlsLabel[5] := L;
  XlsStream.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel));
  XlsStream.WriteBuffer(Pointer(AValue)^, L);
end;

procedure TForm1.Button1Click(Sender: TObject);
var FStream: TFileStream;
  I, J: Integer;
begin
  FStream := TFileStream.Create('c:\e.xls', fmCreate);
  try
     XlsBeginStream(FStream, 0);
     for I := 0 to 99 do
        for J := 0 to 99 do
        begin
           XlsWriteCellNumber(FStream, I, J, 34.34);
          // XlsWriteCellRk(FStream, I, J, 3434);
          // XlsWriteCellLabel(FStream, I, J, Format('Cell: %d,%d', [I, J]));
        end;
     XlsEndStream(FStream);
  finally
     FStream.Free;
end;

+ -

관련 글 리스트
11699 [질문] 엑셀파일로 저장하는 델파이 코드를 C++Builder 코드로.. 이의태 1496 2001/10/10
11814     Re:[질문] 엑셀파일로 저장하는 델파이 코드를 C++Builder 코드로.. 이의태 1275 2001/10/16
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.