텍스트 파일을 엑셀 파일로 변환시키는 프로그래램을 작성하고 있는데요, 엑셀이 안깔려 있어도 변환 되도록 할수는 없나요?
약 150,000개의 데이터를 다루다 보니 처리 시간이 오래 걸려 데이터를 엑셀 파일 포멧으로 바로 변환 시키면 처리 속도가 빨라질 것 같아서요....
스트링 그리드에 업데이트 하는데는 약 4초면 되는데, ExcelApplication 콤포넌트를 사용하면 약 10분 정도 소요 되네요.
고수님들!! 한수 부탁드립니다.
팁테크 방에 [팁] OLE없이 엑셀파일 만들기 를 찾아보세요.
왠만한건 전체검색에 찾으시면 다 있더군요.
엑셀로 읽는다면 csv나 식별자가 있는 텍스트파일 파라독스나 mdb등해도 엑셀이 다 읽고 변환하므로
다양하게 코딩해도 됩니다.
<!--CodeS-->
안녕하세요. 최용일입니다.
OLE를 사용안하고 직접 엑셀파일을 만드는 예제입니다.
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);
procedure TForm1.Button1Click(Sender: TObject);
var
FStream: TFileStream;
I, J: Integer;
begin
FStream := TFileStream.Create('J: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;
end;
왠만한건 전체검색에 찾으시면 다 있더군요.
엑셀로 읽는다면 csv나 식별자가 있는 텍스트파일 파라독스나 mdb등해도 엑셀이 다 읽고 변환하므로
다양하게 코딩해도 됩니다.
<!--CodeS-->
안녕하세요. 최용일입니다.
OLE를 사용안하고 직접 엑셀파일을 만드는 예제입니다.
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);
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('J: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;
end;
출처 by : Borland CodeCentral, Azret Botash
^^ 항상 즐코하세요...
<!--CodeE-->