企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
# Ruby Dir 类和方法 **Dir** | 是一个表示用于给出操作系统中目录中的文件名的目录流。Dir 类也拥有与目录相关的操作,比如通配符文件名匹配、改变工作目录等。 ## 类方法 | 方法 | 描述 | | --- | --- | | **Dir[pat] Dir::glob( pat)** | 返回一个数组,包含与指定的通配符模式 pat 匹配的文件名: **\*** - 匹配包含 null 字符串的任意字符串 **\*\*** - 递归地匹配任意字符串 **?** - 匹配任意单个字符 **[...]** - 匹配封闭字符中的任意一个 **{a,b...}** - 匹配字符串中的任意一个 Dir["foo.*"] # 匹配 "foo.c"、 "foo.rb" 等等 Dir["foo.?"] # 匹配 "foo.c"、 "foo.h" 等等 | | **Dir::chdir( path)** | 改变当前目录。 | | **Dir::chroot( path)** | 改变根目录(只允许超级用户)。并不是在所有的平台上都可用。 | | **Dir::delete( path)** | 删除 path 指定的目录。目录必须是空的。 | | **Dir::entries( path)** | 返回一个数组,包含目录 path 中的文件名。 | | **Dir::foreach( path) {| f| ...}** | 为 path 指定的目录中的每个文件执行一次块。 | | **Dir::getwd Dir::pwd** | 返回当前目录。 | | **Dir::mkdir( path[, mode=0777])** | 创建 path 指定的目录。权限模式可被 File::umask 的值修改,在 Win32 的平台上会被忽略。 | | **Dir::new( path) Dir::open( path) Dir::open( path) {| dir| ...}** | 返回 path 的新目录对象。如果 open 给出一个块,则新目录对象会传到该块,块会在终止前关闭目录对象。 | | **Dir::pwd** | 参见 Dir::getwd。 | | **Dir::rmdir( path) Dir::unlink( path) Dir::delete( path)** | 删除 path 指定的目录。目录必须是空的。 | ## 实例方法 假设 **d** 是 ** |Dir** 类的一个实例: | 方法 | 描述 | | --- | --- | | **d.close** | 关闭目录流。 | | **d.each {| f| ...}** | 为 d 中的每一个条目执行一次块。 | | **d.pos** | d.tell 返回 d 中的当前位置。 | | **d.pos= offset** | 设置目录流中的位置。 | | **d.pos= pos d.seek(pos)** | 移动到 d 中的某个位置。pos 必须是一个由 d.pos 返回的值或 0。 | | **d.read** | 返回 d 的下一个条目。 | | **d.rewind** | 移动 d 中的位置到第一个条目。 | | **d.seek(po s)** | 参见 d.pos=pos。 | | **d.tell** | 参见 d.pos。 |