程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> Delphi >> 在Delphi編程中的文件操作

在Delphi編程中的文件操作

編輯:Delphi

  1、Delphi中拷貝文件的幾種方法

  {方法一:用File stream }
  Procedure FileCopy( Const sourcefilename, targetfilename: String );
  Var
  S, T: TFileStream;
  Begin
  S := TFileStream.Create( sourcefilename, fmOpenRead );
  try
  T := TFileStream.Create( targetfilename,fmOpenWrite or fmCreate );
  try
  T.CopyFrom(S, S.Size ) ;
  finally
  T.Free;
  end;
  finally
  S.Free;
  end;
  End;

  { 方法二:使用內存塊進行讀寫 }

  procedure FileCopy(const FromFile, ToFile: string);
  var
  FromF, ToF: file;
  NumRead, NumWritten: Word;
  Buf: array[1..2048] of Char;
  begin
  AssignFile(FromF, FromFile);
  Reset(FromF, 1);
  AssignFile(ToF, ToFile);
  Rewrite(ToF, 1);
  repeat
  BlockRead(FromF, Buf, SizeOf(Buf), NumRead);
  BlockWrite(ToF, Buf, NumRead, NumWritten);
  until (NumRead = 0) or (NumWritten < > NumRead);
  CloseFile(FromF);
  CloseFile(ToF);
  end;

  2、控制INI文件

  要利用.INI文件做程序有關數據的存儲工作,就需要能讀和寫.INI文件,所以列了如下方法給大家參考:

  {方法一:用 Windows API 函數}

  ① 從.INI文件中獲取字符串
  var
  strResult:array[0..30] of Char;
  begin
  GetPrivateProfileString(' desktop ', 'wallpaper',
  'c:\Windowsewwall.bmp' , strResult, 100,
  'c:\Windows\win.ini' );
  edit1.text:=strResult; //顯示取得字符串
  end;
  ② 從.INI文件中獲取整數
  var
  nResult: integer;
  begin
  nResult := GetPrivateProfileString(' desktop ', ' tilewallpaper',
  0 , 'c:\Windows\win.ini' );
  edit1.text:=intostr(nResult); //顯示取得整數
  end;
  ③ 向.INI文件寫入字符串
  WritePrivateProfileString('desktop', 'wallpaper',
  strWrite ,'c:\Windows\win.ini');
  { 方法二:使用TiniFile進行讀寫 }
  ① 從.INI文件中讀字符串
  var MyIni: TIniFile;
  begin
  MyIni := TIniFile.Create('c:\Windows\win.ini');
  edit1.text:=MyIni.ReadString('Desktop', 'Wallpaper', '');
  end;
  ② 向.INI文件中寫入字符串
  var MyIni: TIniFile;
  begin
  MyIni := TIniFile.Create('c:\Windows\win.ini');
  MyIni.WriteString('desktop', 'wallpaper', 'c:\a.bmp');
  end;

  3、用Delphi實現將純文本資料轉入數據庫

  在我們日常工作中,常會碰到這樣一個難題:一大堆收集好的純文本格式,比較規整的資料怎樣才能將它們分離,轉到自己已經建好的數據庫中進行管理呢?例如,有一段人事檔案資料document.txt,內容如下:

  張強,25,助理工程師,

  王宏,30,工程師,

  李遠,45,高級工程師,

  要將它轉入數據庫中,document.db結構如下:

  姓名,年齡,職稱

  怎麼辦呢?現在通過使用delphi編程,很好地解決了這個難題。Delphi提供了許多功能強大,豐富的字符處理函數和過程,常用的有:

  ① function Length(S:String):Integer  //返回串的長度

  ② function Copy(S:String; Index,Count: Integer):String

  //給出一個字符串中串的拷貝

  ③ function Pos(Substr:String; S:String); Integer  

  //查找子串在字符串中的位置

  ④ Procedure Delete(Var S:String; Index,Count: Integer);

  //從一個字符串中去除子串

  利用Delphi提供的已有函數和過程基礎上編制自己的三個函數,實現了純文本格式資料轉入數據庫功能。只要Delphi支持的數據庫都可以支持。

  Document.txt中每行數據為一個字符串,字符串中每個被分割的數據為一個字段,分割每個字段的字符為分割符,這裡是逗號,也可以是、;#等符號。具體思想是:先將字符串進行調整,然後把串中每個字符同分割符比較,將不是分割符的字符追加到MyStr串中,最後得到一個字段的內容。通過一個循環,就可以將一個字符串分成幾個字段。

  Function GetSubStr(var aString:string; SepChar:String): String;

  //得到字符串中一個子串

  因要改變參數aString的值,所以將它用var定義。

  Function GetSubStrNum(aString, SepChar: String): Integer;

  //計算一個字符串要被分割成幾個字段。

  參數:aString是所需分割的一個字符串,

  SepChar是分割符。
  Function GetSubStrNum(aString:String;SepChar:String):integer;
  var
  i:Integer;
  StrLen:Integer;
  Num:Integer;
  begin
  StrLen:=Length(aString);
  Num:=0;
  For i:=1 to StrLen do
  If Copy(aString,i,1) = SepChar then
  Num:=Num+1;
  result:=Num;
  end;
  Function GetSubStr(var aString:String;SepChar:String):String;
  var
  Mystr:String;
  StrLen:Integer;
  SepCharPos:Integer;
  begin
  StrLen:=Length(aString);
  SepCharPos:=Pos(SepChar,aString); //計算分割符在子串中的位置
  MyStr:=Copy(aString,1,SepCharPos-1); //將分割符前所有字符放到mystr串中
  Delete(aString,1,SepCharPos); //除去分割符和分割符前的子串
  GetSubStr:=MyStr; //返回一個字段
  end;

  有了上面三個函數,現在介紹一下具體的應用:

  ① 首先建立一個窗體Forml,加入一個RichEditl(或Menol),一個按鈕Buttonl和一個Tablel,設置Tablel的屬性:

  Tablell.DataBaseName:= 'c:\test';

  Tablell.TableName:= 'document.db';

  ② 分別加入以下程序:

  const
  SepChar=',' ;
  procedure TForm1.FormCreate(Sender: TObject);
  begin
  RichEdit1.Lines.LoadFromFile('c:\test\test.txt');
  end;
  procedure TForm1.Button1Click(Sender: TObject);
  var
  i,j,num:Integer;
  MyLine:String;
  item:array[1..3] of string;
  begin
  For i:=0 to RichEdit1.Lines.Count-1 do
  begin
  MyLine:=Richedit1.Lines[i];
  num:=GetSubStrNum(myline,SepChar);
  for j:=1 to num do
  item[j]:=GetSubStr(myline,SepChar);
  table1.open;
  with table1 do
  begin
  table1.insert;
  table1name.Asstring:=item[1];
  table1age.Asinteger:=strtoint(item[2]);
  table1title.Asstring:=item[3];
  table1.post;
  end;
  table1.close;
  end;
  end;

  然後就可以進行編譯、運行了。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved