FileSelectFolder


显示允许用户选择文件夹的标准对话框。

FileSelectFolder, OutputVar [, StartingFolder, Options, Prompt]

参数

OutputVar

用来保存用户所选择的文件夹的变量名。如果用户取消了对话框,则该变量将被置为空(比如不想选择文件夹)。若用户选择了根目录(如 C:\),OutputVar 会以反斜杠结尾。如果不需要这个反斜杠,可用下面的方法去掉它:

FileSelectFolder, Folder
Folder := RegExReplace(Folder, "\\$")  ; 若以反斜杠结尾,则去掉它。
StartingFolder

若为空或省略,对话框选择的起始目录为用户的我的文档文件夹(或者可能是我的电脑)。 CLSID 文件夹,比如 ::{20d04fe0-3aea-1069-a2d8-08002b30309d} (也就是我的电脑)可以作为特殊文件被指定为起始目录。

另外,该参数最常见的用法是一个星号通配符后紧跟着作为起始位置的驱动器或文件夹的绝对路径。比如 *C:\ 将把C盘作为起始选择位置。与此类似,*C:\My Folder 将把该文件夹作为起始选择位置。

星号表示允许用户从起始目录向上导航(接近根目录)。如果没有星号,用户只能选择 StartingFolder 中的文件夹(或者 StartingFolder 本身)。省略星号的一个好处是用户不必点击目录前的加号,StartingFolder 一开始即以树状目录形式显示出来。

若存在星呈,向上导航可被限制到除桌面外的某个文件夹。在星号前加上最上级文件夹的绝对路径和一个空格或制表符,即可达到此目的。 在下面的例子中,不允许用户导航到高于 C:\My Folder 的目录(但起始目录为 C:\My Folder\Projects):
C:\My Folder *C:\My Folder\Projects

Options

以下数字之一:

0: 以下所有选项无效(Windows 2000 除外,它可能始终显示“新建文件夹”按钮)。

1 (默认):提供允许用户新建文件夹的按钮。然而,该按钮在 Windows 95/98/NT 中不会出现。

上述数字加 2 提供允许用户输入文件夹名的编辑框。比如该参数为数值 3,则同时提供一个编辑框和一个“新建文件夹”按钮。

上述数字加 4 可以忽略 BIF_NEWDIALOGSTYLE 属性。加4确保了 FileSelectFolder 可以在诸如 WinPE 或者 BartPE 之类的预安装环境中也能正常工作。然而,这可能会妨碍 "新建文件夹" 按钮的出现,至少在 Windows XP 中是这样。["4" 需要 1.0.48+ 版本]

如果用户在编辑框中输入非法文件夹名, OutputVar 将会被置为在导航树中选择的文件夹名,而不是用户输入的名称,至少在 Windows XP 中是这样。

该参数可以是个表达式

Prompt 显示在窗口中,告诉用户该做什么的文字。如果省略或空白,则默认为“选择文件夹 - %A_SCRIPTNAME%"(也就是当前脚本的名称)。

ErrorLevel

如果用户关闭对话框而未选择文件,则 ErrorLevel 被置为 1 (比如按了取消按钮)。如果系统拒绝显示对话框(罕见),该变量也会被置为 1。否则其值为 0。

注意

在 GUI 窗口中,可以用 Gui +OwnDialogs 来显示一个选择文件夹的模式对话框。在模式对话框关闭之前,禁止用户与 GUI 窗口进行交互操作。

已知的限制:在显示 FileSelectFolder 对话框时启动的定时器,将会使用户在对话框中的点击延迟生效,直到该定时器程序执行完毕。为避免这一问题,应避免使用子程序耗时很长的定时器,或者在显示对话框时禁止所有的定时器:

Thread, NoTimers
FileSelectFolder, OutputVar,, 3
Thread, NoTimers, false

相关命令

FileSelectFile, MsgBox, InputBox, ToolTip, GUI, CLSID List, FileCopyDir, FileMoveDir, SplitPath

操作系统还提供提示用户选择字体、颜色或图标的标准对话框。这些对话框可以通过 DllCall() 来显示,示例见 www.autohotkey.com/forum/topic17230.html

示例

FileSelectFolder, OutputVar, , 3
if OutputVar =
    MsgBox, 您未选择文件夹。
else
    MsgBox, 您选择了文件夹 “%OutputVar%”。

CLSID 示例:
FileSelectFolder, OutputVar, ::{20d04fe0-3aea-1069-a2d8-08002b30309d}  ; 我的电脑。
翻译:甲壳虫<jdchenjian@gmail.com>