参考:http://www.cnblogs.com/railgunman/articles/1800318.html
程序设计当中,我们时常遇到需要处理文件、目录及驱动器的情况,这里将对如何处理不同类型的文件进行讲述
主要包括如何使用 TFileStream 类封装文件的输入/输出以及如何利用 32 位windows的主要特征——内存映射文件。将会学到如何创建一个封装内存映射文件功能的 TMemoryMappedFile类,并用它在文本文件中进行文本查询。还提供了一些关于选择驱动器、在树形目录中查询文件以及获取文件版本信息的方法。使你对文件、目录及驱动器有深入的认识。
处理文件的输入/输出
你将要对三种文件进行处理:文本文件、类型文件、二进制文件
以下几节是关于文件输入/输出的讲解。文本文件是指可被任意文本编辑器读取的ASCII文本。类型文件指包含有程序员定义的数据类型的文件。二进制文件包含其他所有的类型,它是对包含任意格式或无格式数据的文件的统称
文本文件的处理
本文讲述使用内建于 Object Pascal运行时库中的过程和函数处理文本文件的方法。在对文本文件进行任何处理之前,首先要打开此文本文件。声明变量:通过此变量可以引用一个文本文件。
打开一个文件需要两步:首先是 AssignFile(),它可以将文件变量与一个文件关联起来。接着进行第二步:打开文件。有三种方法打开文件:使用 ReWrite()过程创建并打开文件,对于一个已经存在的文件,此操作将使得文件被覆盖;使用Reset()过程只读地打开一个文件;使用Append()过程向已经存在的文件追加文本。
注意Reset()将以可读写方式打开类型文件和无类型文件。可以使用 CloseFile()来关闭一个已经打开的文件
文件的打开和关闭
AssignFile | 把一个外部文件名和一个文件变量相关联 |
Reset | 打开一个存在的文件,文本文件(只读),其他文件(读写) |
ReWrite | 创建并打开一个新文件(或者覆盖已有的文件) |
Append | 以追加方式打开一个文件(只适用于文本文件) |
CloseFile | 关闭一个打开的文件 |
FileOpen | 打开一个特定的文件并返回文件句柄 |
FileCreate | 创建一个给定文件名的文件,并返回文件句柄 |
FileClose | 关闭一个特定句柄的文件 |
后面的三个文件主要提供系统内部使用,在文件复制的编程过程中也往往会用到。它们操作的对象时文件句柄,而不是文件变量
文件定位
Seek | 把文件当前位置移至指定部分 |
FilePos | 返回文件当前的位置 |
Eoln | 返回行结束标志 |
EOF | 返回文件结束标志 |
FileSeek | 改变当前文件指针的位置 |
还有一个问题,如何判断文件已打开?要不要读写完成之后就关闭文件,下次读或写时再打开?
用 TFileStream
对于通过 Byte 数组进行文件操作的,在 FTP中经常会使用到,我也是在Delphi调用Web Service进行文件的上传和下载时找到这两个函数的,挺好用的,推荐给大家。(申明:非本人所写)
<1>将Byte数组生成文件
procedure ByteArrayToFile(Const ByteArray : TByteDynArray; Const FileName : String); var Conut : Integer; F : File of Byte; pTemp : Pointer; begin AssignFile(F, FileName); ReWrite(F); try Count := Length(ByteArray); pTemp := @ByteArray[0]; BlockWrite(F, pTemp^, Count); finally CloseFile(F); end; end;
<2>将文件生成Byte数组
function FileToByteArray(const FileName : String) :TButeBtnArray; const BLOCK_SIZE = 1024; var BytesRead, BytesToWrite, Count :Integer; F :Filw of Byte; pTemp : Pointer; begin AssignFile(F, FileName); Reset(F); try Count := FileSize(F); SetLength(Result, Count); pTemp := @Result[0]; BytesRead := BLOCK_SIZE; while(BytesRead = BLOCK_SIZE) do begin BytesToWrite := Min(Count, BLOCK_SIZE); BlockRead(F, pTemp^, BytesToWrite, BytesRead); pTemp := Pointer(LongInt(pTemp)+BLOCK_SIZE); Count := Count-BytesRead; end; finally CloseFile(F); end; end;
function Encrypt(mStr : String; mKey : String) :String; var I, J :Integer; begin J:=1; Result := ''; for I:=1 to Length(mStr) do begin Result := Result + Char(Ord(mStr[I] xor Ord(mKey[j])); if J + 1 <= Length(mKey) then Inc(J) else J:=1; end; {自己加步骤} end;
function Decrypt(mStr : String; mKey : String) :String; var I,J: Integer; begin J :=1; Result := ''; {自己加步骤} for I :=1 to Length(mStr) do begin Result := Result + Char(Ord(mStr[I] xor Ord(mKey[J])); if J+1 <= Length(mKey) then; Inc(J) else J:=1; end; end;
procedure TForm1.Button1Click(Sender : TObject); const cKey1 = '谁想试试怎么破'; cKey2 = '我可不愿意这样玩(1)我可不愿意这样玩(2)我可不愿意这样玩(3)'; cKey3 = 'Memo2.Text := Decrypt(Encrypt(Memo1.Text, cKey), cKey);'; var S :String; //加密后的字符 begin S := Encrypt(Encrypt(Encrypt(Memo1.Text, cKey1), cKey2), cKey3); ShowMessage(S); Memo2.Text := Decrypt(Decrypt(Decrypt(S, cKey3), cKey2), cKey1); end;