文件的拖放和打开拖拽

user shellapi
type
TForm1 = class(TForm)
ListView1: TListView;
procedure FormCreate(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
procedure AppMessage(var Msg: TMsg; var Handled: Boolean);///消息处理函数
end;procedure TForm1.FormCreate(Sender: TObject);
begin
//设置需要处理文件WM_DROPFILES拖放消息
DragAcceptFiles(ListView1.Handle, TRUE);
//设置AppMessage过程来捕获所有消息
Application.OnMessage := AppMessage;
end;
procedure TForm1.AppMessage(var Msg: TMsg; var Handled: Boolean);
var
nFiles, I: Integer;
Filename: string;
ListItem: TListItem;
begin
//
// 注意!所有消息都将通过这里!
// 不要在此过程中编写过多的或者需要长时间操作的代码,否则将影响程序的性能
//
// 判断是否是发送到ListView1的WM_DROPFILES消息
if (Msg.message = WM_DROPFILES) and (msg.hwnd = ListView1.Handle) then
begin
// 取dropped files的数量
nFiles := DragQueryFile (Msg.wParam, $FFFFFFFF, nil, 0);
// 循环取每个拖下文件的全文件名
for I := 0 to nFiles - 1 do////支持拖动多个文件过来
begin
// 为文件名分配缓冲 allocate memory
SetLength (Filename, 80);
// 取文件名 read the file name
DragQueryFile (Msg.wParam, I, PChar (Filename), 80);
Filename := PChar (Filename);
//file://将全文件名分解程文件名和路径
////FileName为拖过来的文件,包括文件全路径。
///此处实现对文件的操作
end;
//file://结束这次拖放操作
DragFinish (Msg.wParam);
//file://标识已处理了这条消息
Handled := True;
end;
end;

View Code

拖动获取文件路径的技术

unit Unit1;
interface
uses
Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
shellapi, StdCtrls;
type
TForm1 = class(TForm)Memo1: TMemo;procedure FormCreate(Sender: TObject);
private{ Private declarations }
publicprocedure WMDropFiles(var message:TMessage);message WM_DROPFILES;{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.dfm}
procedure tform1.WMDropFiles(var message:TMessage);
//响应拖动事件,讲文件的路径放置到Memo控件中
varp:array[0..254] of char;i:word;
begininherited;memo1.lines.clear;i:=dragqueryfile(message.wparam,$ffffffff,nil,0);caption :=inttostr(i);for i:=0 to i-1 dobegindragqueryfile(message.wparam,i,p,255);//取得文件路径
      memo1.lines.Add(strpas(p));end;
end;
procedure TForm1.FormCreate(Sender: TObject);
//设定拖动句柄
begindragacceptfiles(form1.handle,true);
end;
end.
==============
object Form1: TForm1
Left = 211
Top = 186
Width = 396
Height = 173
Caption = 'Form1'
Color = clBtnFace
Font.Charset = DEFAULT_CHARSET
Font.Color = clWindowText
Font.Height = -11
Font.Name = 'MS Sans Serif'
Font.Style = []
OldCreateOrder = False
OnCreate = FormCreate
PixelsPerInch = 96
TextHeight = 13
object Memo1: TMemoLeft = 80Top = 32Width = 193Height = 73Lines.Strings = ('Memo1')TabOrder = 0
end
end

View Code

判断文件是否为文本文件的函数

在用Delphi 编程处理文本文件的时候,如果要装载的文件比较大,你可能会想在文件装载过程中提供一个装载进度的提示--那么你就必需自己编写直接通过文件打开/读取函数来装载文件内容的函数。
在自己编写文本文件读取函数的时候,你首先会遇到的第一个问题就是:对于给定的一个文件名,怎么知道它所代表磁盘文件的确是文本文件?这里有一个很简单的方法:把给定的那个文件看作是无类型的二进制文件,然后顺序地读出这个文件的每一个字节,如果文件里有一个字节的值等于0,那么这个文件就不是文本文件;反之,如果这个文件中没有一个字节的值是0的话,就可以判定这个文件是文本文件了。这是原理,下面看看在Delphi 中怎样编程来实现它--
代码如下:

function IsTextFile(FileName:string):boolean;
var
Fs:TFileStream;
i,size:integer;
IsTextFile:boolean;
ByteData:Byte;
begin
if FileExists(FileName) then
begin
Fs:=TFileStream.Create(FileName,fmOpenRead);
IsTextFile:=true;
i:=0;
size:=Fs.Size;
While (i<size) and IsTextFile do
begin
Fs.Read(ByteData,1);
IsTextFile:=ByteData<>0;
inc(i)
end;
Fs.Free;
Result:=IsTextFile
end
else
Result:=false
end;

View Code

判断文件路径,不存在则建立

procedure TForm1.Act_CheckPath(FilePath:String);
var
MyFile:String;
i:Integer;
FileDir,TemStr:WideString;
PosList,DirList:TStrings;
begin
PosList:=TStringList.Create;
DirList:=TStringList.Create;
MyFile:=FilePath+'\';
FileDir:=MyFile;
//记录'\'的位置;
for i:=1 to Length(FileDir) do
begin
TemStr:=Copy(FileDir,i,1);
if TemStr = '\' then
PosList.Add(IntToStr(i));
end;
for i:=0 to PosList.Count - 1 do
begin
DirList.Add(Copy(FileDir,1,StrToInt(PosList.Strings[i])-1));
end;
for i:=0 to DirList.Count -1 do
begin
//判断文件路径是否存在
if not DirectoryExists(DirList.Strings[i]) then
//不存在,则建立新路径
CreateDir(DirList.Strings[i]);
end;
PosList.Free;
DirList.Free;
end; 

View Code

判断文件夹(目录)是否存在,不存在就创建一个

Delphi判断文件夹(目录)是否存在,不存在就创建一个,可以一次创建多级目录

procedure TForm1.Button1Click(Sender: TObject);
begin
if not FileExists(Edit1.Text) then
//if not DirectoryExists(Edit1.Text) then 判断目录是否存在
try
begin
CreateDir(Edit1.Text);
//ForceDirectories(Edit1.Text); 创建目录
end;
finally
raise Exception.Create('Cannot Create '+Edit1.Text);
end;end;

View Code

//该代码片段来自于: http://www.sharejs.com/codes/delphi/8998
//三个函数引用自SysUtils单元

FileExists(Path)检查目录是否存在function FileExists(const FileName: string): Boolean;DirectorysExists(Path)创建目录function DirectoryExists(const Directory: string): Boolean;CreateDirectory(Path)创建目录function ForceDirectories(Dir: string): Boolean;ForceDirectories(Path)创建目录CreateDirectory(Path)创建目录forcedirectories和CreateDirectory都能创建文件
ForceDirectories可以创建多层目录. 

View Code

如果你创建一个目录为c:\mymusic\music
如果你的C盘不存在一个叫mymusic的文件夹
的话程序会自动创建,函数执行的结果是,
创建了两个文件夹,mymusic和music,music为
mymusic的子文件夹.

CreateDirectory只能创建一个文件夹,如果
mymusic不存在,则反回创建music文件夹失败!

移动文件到已知路径 用按钮事件实现

Delphi的移动文件方法(转)/删除文件:/文件的复制

RenameFile,DeleteFile,MoveFile

Delphi的移动文件方法

usesShellApi;procedure ShellFileOperation(fromFile: string; toFile: string; Flags: Integer);varshellinfo: TSHFileOpStructA;beginwith shellinfo dobeginwnd := Application.Handle;wFunc := Flags;pFrom := PChar(fromFile);pTo := PChar(toFile);end;SHFileOperation(shellinfo);end;// Example, Beispiel:procedure TForm1.Button1Click(Sender: TObject);beginShellFileOperation('c:\afile.txt', 'd:\afile2.txt', FO_COPY);// To Move a file: FO_MOVEend;

View Code

该方法的另一种表示:

function TScanFileThread.MoveFile(FileName: string): Boolean;var F: TShFileOpStruct;begin with F do begin Wnd := Handle;wFunc := FO_MOVE;pFrom := PChar(Directory + FileName + #0#0);pTo := PChar(SaveDirectory + FileName + #0#0);fFlags := FOF_RENAMEONCOLLISION or FOF_NOCONFIRMMKDIR;end;if ShFileOperation(F) = 0 then beginResult := True;endelsebeginResult := False;end;end;

View Code

一开始pFrom和pTo没有以“#0#0”结尾,结果发现在有的机器上能移动成功,有的机器上SHFileOperation返回1026无法转移,查了一下资料

ShFileOperation中的pFrom和pTo中可以包含多个文件名,文件名之间用 '\0' 分割,最后以两个\0结束。

/

1、

CopyFile(PChar(源目录),PChar(目标目录),True);CopyFileTo('F:\MyProject\delphi\message\data\data.mdb','c:\data.mdb');//不能覆盖已存在的文件******//

View Code

//***************下面的这个WINAPI最后的一个参数为true时不覆盖已经存在的文件。为false时自动覆盖存在的文件。*********//

CopyFile(pchar(''+MyPath+'/data/data.mdb'),pchar(''+MyPath+'/data/backup.mdb'),false);

2、api的不会

我一般是在程序中根据程序所在目录建立一个批处理文件

copy x:\xxx\xxx.exe c:;

exit;

在窗体创建或退出时执行;

因为在外地网吧,所以不能提供代码,不过这个应该不难。

3、也可以直接调用shellexec winexec,

shellexec('copy gp.exe c:')

4、不用api的如下:

procedure CopyFile (SourceName, TargetName: String);varStream1, Stream2: TFileStream;beginStream1 := TFileStream.Create (SourceName, fmOpenRead);tryStream2 := TFileStream.Create (TargetName, fmOpenWrite or fmCreate);tryStream2.CopyFrom (Stream1, Stream1.Size);finallyStream2.Free;endfinallyStream1.Free;endend;

View Code

5、如果是在本程序运行的时候复制本程序的话,可以这样:

procedure Tform1.formCreate(Sender: TObject);vars:Pchar;begins:= Pchar(Application.ExeName);copyfile(s, 'c:\a.exe', true);end;

View Code

6、CopyFile(PChar(源文件),PChar(目标文件),True);为False表示覆盖

7、可以用以下的方法:

CopyFile(pchar('c:\sql.txt'), pchar('d:\sql.txt'), True);

只要是文件的复制,都可以。

移动文件:

MoveFile(pchar('c:\sql.txt'), pchar('d:\sql.txt'));

删除文件:

DeleteFile('c:\sql.txt');

以上都是可行的。

 判断文件是否正在被使用

首先,我们先来认识下CreateFile函数,它的原型如下
HANDLE CreateFile(
LPCTSTR lpFileName, //指向文件名的指针
DWORD dwDesiredAccess, //访问模式(写/读)
DWORD dwShareMode, //共享模式
LPSECURITY_ATTRIBUTES lpSecurityAttributes, //指向安全属性的指针
DWORD dwCreationDisposition, //如何创建
DWORD dwFlagsAndAttributes, //文件属性
HANDLE hTemplateFile //用于复制文件句柄
);

下面是参数的说明

lpFileName
指向一个空结尾字符串。该参数指定了用于创建或打开句柄的对象。
如果lpFileName的对象是一个路径,则有一个最大字符数的限制。不能超过常量(MAX_PATH).这个限制指示了CreateFile函数如何解析路径.

dwDesiredAccess
指定对象的访问方式,程序可以获得读访问权,写访问权,读写访问权或者是询问设备("device query") 访问权.
这个参数可以是下列值的任意组合
0
指定询问访问权.程序可以在不直接访问设备的情况下查询设备的属性.
GENERIC_READ
指定读访问权.可以从文件中读取数据,并且移动文件指针.可以和GENERIC_WRITE组合成为"读写访问权".
GENERIC_WRITE
指定写访问权.可以从文件中写入数据,并且移动文件指针.可以和GENERIC_READ组合成为"读写访问权".

dwShareMode
设置位标志指明对象如何共享.如果参数是0, 对象不能够共享. 后续的打开对象的操作将会失败,直到该对象的句柄关闭.
使用一个或多个下列值的组合来共享一个对象.
FILE_SHARE_DELETE
WINDOWS NT:后续的仅仅请求删除访问权的打开操作将会成功.
FILE_SHARE_READ
后续的仅仅请求读访问权的打开操作将会成功.
FILE_SHARE_WRITE
后续的仅仅请求写访问权的打开操作将会成功.

lpSecurityAttributes
指向一个 SECURITY_ATTRIBUTES 结构的指针用于确定如何在子进程中继承这个句柄.如果这个参数是NULL,则该句柄不可继承.

dwCreationDisposition
指定当文件存在或者不存在时如何动作。关于这个参数更多的信息,参考批注部分。这个参数必须是一个或多个下列值。
CREATE_NEW
创建一个新文件. 如果该文件已经存在函数则会失败.

CREATE_ALWAYS
创建一个新文件.如果该文件已经存在,函数将覆盖已存在的文件并清除已存在的文件属性
OPEN_EXISTING
打开一个文件,如果文件不存在函数将会失败.
如查你使用CreateFile函数为设备装载控制台.请查看批注中的"为什么使用OPEN_EXISTING标志"的部分.

OPEN_ALWAYS
如果文件存在,打开文件. 如果文件不存在,并且参数中有CREATE_NEW标志,则创建文件.
TRUNCATE_EXISTING
打开一个文件,每次打开,文件将被截至0字节.调用进程必须用GENERIC_WRITE访问模式打
开文件.如果文件不存在则函数就会失败.

dwFlagsAndatributes
为文件指定属性和标志位
该参数可以接收下列属性的任意组合.除非其它所有的文件属性忽略FILE_ATTRIBUTE_NORMAL.
FILE_ATTRIBUTE_ARCHIVE
文件将被存档,程序使用此属性来标志文件去备份或移除
FILE_ATTRIBUTE_HIDDEN
文件被隐藏,它不会在一般文件夹列表中被装载.
FILE_ATTRIBUTE_NORMAL
文件没有被设置任何属性.

FILE_ATTRIBUTE_OFFLINE
文件的数据没有被立即用到。指出正在脱机使用该文件。
FILE_ATTRIBUTE_READONLY
这个文件只可读取.程序可以读文件,但不可以在上面写入内容,也不可删除.
FILE_ATTRIBUTE_SYSTEM
文件是系统的一部分,或是系统专用的.
FILE_ATTRIBUTE_TEMPORARY
文件被使用后,文件系统将努力为(文件的)所有数据的迅迅访问保持一块
内存。临时文件应当在程序不用时及时删除。

dwFlagAndAttributes可以接受下列标志的任意组合。

FILE_FLAG_WRITE_THROUGH
指示系统通过快速缓存直接写入磁盘.
FILE_FLAG_OVERLAPPED
指示系统初始化对象, 此操作将对进程设置一个引用计数并返回ERROR_IO_PENDING.处理完成后, 指定对象将被设置为信号状态.当你指定FILE_FLAG_OVERLAPPED时,读写文件的函数必须指定一个OVERLAPPED结构.并且. 当FILE_FLAG_OVERLAPPED被指定, 程序必须执行重叠参数(指向OVERLAPPED结构)去进行文件的读写.这个标志也可以有超过一个操作去执行.
FILE_FLAG_NO_BUFFERING
指示系统不使用快速缓冲区或缓存,当和FILE_FLAG_OVERLAPPED组合,该标志给出最大的异步操作量, 因为I/O不依赖内存管理器的异步操作.然而,一些I/O操作将会运行得长一些,因为数据没有控制在缓存中.当使用FILE_FLAG_NO_BUFFERING打开文件进行工作时,

程序必须达到下列要求:
文件的存取开头的字节偏移量必须是扇区尺寸的整倍数.
文件存取的字节数必须是扇区尺寸的整倍数.例如,如果扇区尺寸是512字节程序就可以读或者写512,1024或者2048字节,但不能够是335,981或者7171字节.
进行读和写操作的地址必须在扇区的对齐位置,在内存中对齐的地址是扇区尺寸的整倍数.
一个将缓冲区与扇区尺寸对齐的途径是使用VirtualAlloc函数. 它分配与操作系统内存页大小的整倍数对齐的内存地址.因为内存页尺寸和扇区尺寸--2都是它们的幂.
这块内存在地址中同样与扇区尺寸大小的整倍数对齐.
程序可以通过调用GetDiskFreeSpace来确定扇区的尺寸.

FILE_FLAG_RANDOM_ACCESS
指定文件是随机访问,这个标志可以使系统优化文件的缓冲.FILE_FLAG_SEQUENTIAL_SCAN
指定文件将从头到尾连续地访问.这个标志可以提示系统优化文件缓冲. 如果程序在随机访问文件中移动文件指针,优化可能不会发生;然而,正确的操作仍然可以得到保证
指定这个标志可以提高程序以顺序访问模式读取大文件的性能, 性能的提高在许多程序读取一些大的顺序文件时是异常明显的.但是可能会有小范围的字节遗漏.FILE_FLAG_DELETE_ON_CLOSE
指示系统在文件所有打开的句柄关闭后立即删除文件.不只有你可以指定FILE_FLAG_DELETE_ON_CLOSE如果没有使用FILE_SHARE_DELETE,后续的打开文件的请求将会失败.FILE_FLAG_BACKUP_SEMANTICS
WINDOWS NT:指示系统为文件的打开或创建执行一个备份或恢复操作. 系统保证调用进程忽略文件的安全选项,倘若它必须有一个特权.则相关的特权则是SE_BACKUP_NAME和SE_RESTORE_NAME.
你也可以使用这个标志获得一个文件夹的句柄,一个文件夹句柄能够象一个文件句柄一样传给某些Win32函数。FILE_FLAG_POSIX_SEMANTICS
指明文件符合POSIX标准.这是在MS-DOS与16位Windows下的标准.
FILE_FLAG_OPEN_REPARSE_POINT
指定这个标志制约NTFS分区指针.该标志不能够和CREAT_ALWAYS一起使用.
FILE_FLAG_OPEN_NO_RECALL
指明需要文件数据,但是将继续从远程存储器中接收.它不会将数据存放在本地存储器中.
这个标志由远程存储系统或等级存储管理器系统使用.hTemplateFile
为GENERIC_READ访问的模式指定一个句柄到模板文件.模板文件在文件开始创建后提供文件属性和扩展属性.Return Values
返回值

View Code

如果函数成功,返回一个打开的指定文件的句柄.如果指定文件在函数调用前已经存在并且dwCreation参数是CREATE_ALWAYS 或者OPEN_ALWAYS,调用GetLastError就会返回ERROR_ALREADY_EXISTS(表示函数成功). 如果函数文件在调用前不存在则会返回0.
如果函数失败,返会值会是INVALID_HANDLE_VALUE. 更多的错误信息可以调用GetLastError来获得.
==================================================================================
“判断文件是否正在被使用”的函数更容易理解一些,函数如下:

function IsFileInUse(fName : string) : boolean;
var
HFileRes : HFILE;
begin
Result := false; //返回值为假(即文件不被使用)
if not FileExists(fName) then exit; //如果文件不存在则退出
HFileRes := CreateFile(pchar(fName), GENERIC_READ or GENERIC_WRITE,
0 {this is the trick!}, nil, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
Result := (HFileRes = INVALID_HANDLE_VALUE); //如果CreateFile返回失败 那么Result为真(即文件正在被使用)
if not Result then //如果CreateFile函数返回是成功
CloseHandle(HFileRes); //那么关闭句柄
end;

View Code

函数的调用方法:IsFileInUse(要判断的文件路径); 如果函数返回True 则正在使用,False则文件现在没被使用

 取得桌面文件夹的路径和取得我的文档的路径

function GetShellFolders(strDir: string): string;
constregPath = '\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders';
varReg: TRegistry;strFolders: string;
beginReg := TRegistry.Create;tryReg.RootKey := HKEY_CURRENT_USER;if Reg.OpenKey(regPath, false) then beginstrFolders := Reg.ReadString(strDir);end;finallyReg.Free;end;result := strFolders;
end;{获取桌面}function GetDeskeptPath: string;
beginResult := GetShellFolders('Desktop'); //是取得桌面文件夹的路径
end;{获取我的文档}function GetMyDoumentpath: string;
beginResult := GetShellFolders('Personal'); //我的文档
end;

View Code

文件夹操作

usesShellApi//建立文件夹
procedure TfrmMain.cxButton1Click(Sender: TObject);
beginCreateDirectory(PChar(ExtractFilePath(ParamStr(0))+ 'Microblue'),nil);
end;//删除文件夹,放到回收站
procedure TfrmMain.cxButton2Click(Sender: TObject);
varT: TSHFileOpStruct;P: String;
beginP := ExtractFilePath(ParamStr(0)) + 'Microblue';with T dobeginWnd := 0;wFunc := FO_DELETE;pFrom := PChar(P);pTo := nil;fFlags := FOF_ALLOWUNDO + FOF_NOERRORUI;hNameMappings := nil;lpszProgressTitle := '正在删除文件夹';fAnyOperationsAborted := False;end;if SHFileOperation(T) = 0 thenbeginShowMessage('删除成功!');endelsebeginShowMessage('删除失败!');end;
end;//直接删除文件夹
procedure TfrmMain.cxButton3Click(Sender: TObject);
beginRemoveDirectory (Pchar(ExtractFilePath(ParamStr(0))+ 'Microblue'));
end;移动文件夹
用 SHFileOperation 这个吧,它能做的事情实在太多了,在MSDN查查这个函数,相信你收获一定不少,呵呵:use Shellapi; //记得 use Shellapifunction MoveDir(const aSrc, aDst: String): Boolean;
varsfo: TShFileOpStruct;i: Integer;
beginFillChar(sfo,SizeOf(TShFileOpStruct),0);sfo.fFlags:=FOF_NOCONFIRMATION or FOF_NOCONFIRMMKDIR or FOF_SILENT or FOF_ALLOWUNDO;sfo.Wnd:=0;sfo.wFunc:=FO_MOVE;sfo.pFrom:=PChar(aSrc);sfo.pTo:=PChar(aDst);Result:=not BOOL(SHFileOperation(sfo));
end;procedure TForm1.FormCreate(Sender: TObject);
beginSHOWMESSAGE(BoolToStr(MoveDir('C:\www','D:\abcd'),True));
end;

View Code

获取文件夹目录列表

procedure TForm1.Button1Click(Sender: TObject);
varvStr: TStringList;i: Integer;
beginvStr := TStringList.Create;findall('E:\', 'test', vStr);for i := 0 to vStr.Count - 1 doShowMessage(vStr[i]);vStr.Free;
end;procedure TForm1.findall(disk, path: String; var fileresult: TStringList);
varfpath, s: String;fs: TsearchRec;
beginfpath := disk + path + '\*.*';if FindFirst(fpath, faAnyFile, fs) = 0 thenbeginif (fs.Name <> '.') and (fs.Name <> '..') thenif (fs.Attr and faDirectory) = faDirectory thenfindall(disk, path + '\' + fs.Name, fileresult)elsefileresult.add(strpas(strupper(pchar(path))) + '\' + strpas(strupper(pchar(fs.Name))) + '(' + inttostr(fs.Size) + ')');while findnext(fs) = 0 dobeginif (fs.Name <> '.') and (fs.Name <> '..') thenif (fs.Attr and faDirectory) = faDirectory thenfindall(disk, path + '\' + fs.Name, fileresult)elsebeginfileresult.add(path + '\' + strpas(strupper(pchar(fs.Name)))+ '(' + inttostr(fs.Size) + ')');end;end;end;Findclose(fs);
end;

View Code

程序获取自身运行目录的方法

Delphi 在启动应用程序时与 C 语言一样会传递命令行参数给应用程序,第一个参数(索引号为零)表示应用程序本身的文件名(包括完整的路径),这个 String 参数由函数 ParamStr(0) 返回。 顺便说一句,Delphi 提供了分析文件名的多个函数,如果你需要从文件名中得到路径名,可用下面的两个函数,这两个函数有一点点微小的差别:ExtractFilePath(FileName:String) 该函数返回路径名,其结尾字符总是“\”ExtractFileDir(FileName:String) 该函数同样返回路径名,但不包括结尾的字符“\”,除非返回的路径是根目录。
例如:获取当前程序的路径时就应该这样写
var
path:string;
………
path:=ExtractFilePath(ParamStr(0));如果调用同一目录下的aa.ini文件,就应该这样写
inifilename:string;
inifilename:=path+'aa.ini';另外,Delphi自己还提供了一个取得当前目录的函数:GetCurrentDir,返回值不包括结尾的字符“\”,除非返回的路径是根目录。以下是个例子:
inifilename:=GetCurrentDir + '\abc.txt';
需要注意的是,GetCurrentDir只有在程序刚运行时取得的是程序运行目录,如果运行过程中改变过当前目录,则该函数返回的结果也会跟着改变。

转载于:https://www.cnblogs.com/blogpro/p/11344819.html

delphi 文件夹操作相关推荐

  1. C++ :常用文件、文件夹操作汇总

    文件.文件夹操作 1.创建文件夹 2.创建文件 3.删除文件 4.删除文件夹 5.删除一个目录下所有的文件夹 6.清空文件夹 7.读取文件 8.写入文件 9.写入随机文件 10.读取文件属性 11.写 ...

  2. php文件域的作用,PHP作用域和文件夹操作示例

    1.作用域 1.1变量作用域 1.全局变量:在函数外面 2.局部变量:在函数里面,默认情况下,函数内部是不会访问函数外部的变量 3.超全局变量:可以在函数内部和函数外部访问 在函数内部访问全局变量&l ...

  3. Python基础day07 作业解析【文件操作(文件读写、文件夹操作)】

    视频.源码.课件.软件.笔记:超全面Python基础入门教程[十天课程]博客笔记汇总表[黑马程序员] Python基础day07[文件读写.文件夹操作.面向对象(类.对象)] 目录 加强训练 题目1 ...

  4. python的文件操作os_python文件、文件夹操作OS模块

    ''' 一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法. 1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 2.返回指定目录下的 ...

  5. LeetCode 1598. 文件夹操作日志搜集器

    文章目录 1. 题目 2. 解题 1. 题目 每当用户执行变更文件夹操作时,LeetCode 文件系统都会保存一条日志记录. 下面给出对变更操作的说明: "../" :移动到当前文 ...

  6. python处理文件夹_python文件及文件夹操作

    1.open()各模式详情 'r'        以只读模式打开,没有write()方法,默认打开方式 'w'       以只写模式打开,文件不存在时会自动创建文件,文件已存在时会清除文件内容并重建 ...

  7. 文件、文件夹操作(I)

    遍历一个目录下的所有文件 首先我们获取用户文档目录路径 1 let manager = FileManager.default 2 let urlForDocument = manager.urls( ...

  8. PHP 文件夹操作「复制、删除、查看大小」递归实现

    PHP虽然提供了 filesize.copy.unlink 等文件操作的函数,但是没有提供 dirsize.copydir.rmdirs 等文件夹操作的函数(rmdir也只能删除空目录).所以只能手动 ...

  9. import java文件,java 文件夹操作,java文件夹,import java.

    java 文件夹操作,java文件夹,import java.import java.io.File; import java.io.FileInputStream; import java.io.F ...

最新文章

  1. python求圆柱表面积_python基础知识-字典
  2. linux 文件缓冲区,如何查看 Linux 当前缓存了哪些大文件?
  3. ExoPlayer 开发者指导
  4. 广州那所大学有自考计算机专业,广州自考本科大学有哪些
  5. centos5安设apache和svk运用域用户验证
  6. elasticsearch中 refresh 和flush区别【转】
  7. Less学习笔记 -- Mixins(混合)一
  8. centos7配置安装redis
  9. 以前的项目今日打开突然报错了!
  10. 【初窥javascript奥秘之闭包】叶大侠病都好了,求不踩了:)
  11. cudaMalloc和cudaMallocPitch
  12. Rust是如何实现内存安全的--理解RAII/所有权机制/智能指针/引用
  13. 【kafka】kafka 消息 重放 从 一个 topic 导入 另外一个 topic
  14. 神奇_程序cmd命令窗口运行会自动停止_加解决方案---Linux工作笔记045
  15. [POJ1469 COURSES]
  16. iOS 关于BTC 一些知识点
  17. 冻库正常低压力是多少_弹涂鱼上市卖不动,还有8万斤要进冻库,市场低迷,不值钱了...
  18. numpy基础1多维数组对象
  19. 表格闪退怎么解决_win10中excel2013闪退怎么修复_win10中excel2013闪退如何解决
  20. MySQL数据库环境变量设置

热门文章

  1. 19个极度冷门发大财职业
  2. 天津滨海服务外包产业园年底投入使用
  3. 捍卫自由的互联网,对 Web3 说不
  4. thinkphp6 短信宝/腾讯云发送手机号验证码
  5. 电子邮件服务器组成部分,电子邮件三大组成部分
  6. 平安好医生与近50家大型医院合作共建“互联网医院”
  7. 服务器托管vs自建机房哪个好?
  8. 安装Python遇到“0x80070643发生严重错误”
  9. stp文件怎么变文件夹_stp文件怎么打开?
  10. java font 字体库,「Font」- 编程字体 @20210209