Q&A

  • *.txt 화일을 TTable 에 읽어 들이는 방법 질문입니다.
왕초보입니다.^^;
file1.txt 을 읽어 TTable 로 읽어 들여 다시 BatchMove로 oracle table로 구축하려합니다.
문제는 TTable로 읽어 들일때 발생하는데, file1.txt 의 첫번째 문자열 길이를 인식하여 그 아래 모든
문자열을 첫번째 문자열 길이만큼만 TTable로 읽어들여집니다.
한 라인의 길이가 일정치 않은 화일로 구축해야 되는대요..
이런 txt 화일을 TTable로 올리려면 어떻게 해야될까요? 아래 소스코드와 증상설명입니다.
*.sch 를 생성하는 방법을 제외하고 해결 방법이 궁금합니다.

<!--CodeS-->

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  StdCtrls, FileCtrl, Grids, DBGrids, Db, DBTables;

type
  TForm1 = class(TForm)
    Table1: TTable;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    DirectoryListBox1: TDirectoryListBox;
    DriveComboBox1: TDriveComboBox;
    FileListBox1: TFileListBox;
    Edit1: TEdit;
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.DFM}

procedure TForm1.Button1Click(Sender: TObject);
begin
  Table1.DatabaseName := DirectoryListBox1.Directory;
  Table1.TableName := Edit1.Text;
  Table1.TableType := ttASCII;
  Table1.Open;
end;

end.

<!--CodeE-->

file1.txt 의 내용

123|123|123
1234|1234|1234

읽어 들인 내용은

123|123|123
1234|1234|1

두번째 라인 '234'가 짤림...
0  COMMENTS