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
[11624] [질문] 엑셀파일에 직접 쓰는 델파이 코드를 빌더에서 사용하려면?
이의태 [bongsaja] 1005 읽음    2001-10-08 11:02
안녕하세요. 다음 코드는 델파이에서 엑셀프로그램 없이 직접 엑셀파일을 만들고 기록하는 코드입니다.
이 코드를 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;

+ -

관련 글 리스트
11624 [질문] 엑셀파일에 직접 쓰는 델파이 코드를 빌더에서 사용하려면? 이의태 1005 2001/10/08
11664     Re:[질문] 엑셀파일에 직접 쓰는 델파이 코드를 빌더에서 사용하려면? 개박살.U&I 816 2001/10/09
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.