参考:http://www.cnblogs.com/railgunman/articles/1800318.html 程序设计当中,我们时常遇到需要处理文件、目录及驱动器的情况,这里将对如何处理不同类型的文件进行讲述 主要包括如何使用 TFileStream 类封装文件的输入/输出以及如何利用 32 位windows的主要特征——内存映射文件。将会学到如何创建一个封装内存映射文件功能的 TMemoryMappedFile类,并用它在文本文件中进行文本查询。还提供了一些关于选择驱动器、在树形目录中查询文件以及获取文件版本信息的方法。使你对文件、目录及驱动器有深入的认识。
处理文件的输入/输出 你将要对三种文件进行处理:文本文件、类型文件、二进制文件 以下几节是关于文件输入/输出的讲解。文本文件是指可被任意文本编辑器读取的ASCII文本。类型文件指包含有程序员定义的数据类型的文件。二进制文件包含其他所有的类型,它是对包含任意格式或无格式数据的文件的统称 文本文件的处理 本文讲述使用内建于 Object Pascal运行时库中的过程和函数处理文本文件的方法。在对文本文件进行任何处理之前,首先要打开此文本文件。声明变量:通过此变量可以引用一个文本文件。 打开一个文件需要两步:首先是 AssignFile(),它可以将文件变量与一个文件关联起来。接着进行第二步:打开文件。有三种方法打开文件:使用 ReWrite()过程创建并打开文件,对于一个已经存在的文件,此操作将使得文件被覆盖;使用Reset()过程只读地打开一个文件;使用Append()过程向已经存在的文件追加文本。 注意Reset()将以可读写方式打开类型文件和无类型文件。可以使用 CloseFile()来关闭一个已经打开的文件 文件的打开和关闭
后面的三个文件主要提供系统内部使用,在文件复制的编程过程中也往往会用到。它们操作的对象时文件句柄,而不是文件变量 文件定位
还有一个问题,如何判断文件已打开?要不要读写完成之后就关闭文件,下次读或写时再打开? 用 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;
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论