- Ruby 基础
- Ruby - 首页
- Ruby - 概述
- Ruby - 环境搭建
- Ruby - 语法
- Ruby - 类和对象
- Ruby - 变量
- Ruby - 运算符
- Ruby - 注释
- Ruby - IF...ELSE
- Ruby - 循环
- Ruby - 方法
- Ruby - 代码块
- Ruby - 模块
- Ruby - 字符串
- Ruby - 数组
- Ruby - 哈希表
- Ruby - 日期和时间
- Ruby - 范围
- Ruby - 迭代器
- Ruby - 文件 I/O
- Ruby - 异常
Ruby - 文件类和方法
一个文件代表一个连接到普通文件的stdio对象,并为普通文件返回此类的实例。
类方法
序号 | 方法和描述 |
---|---|
1 | File::atime( path) 返回path的最后访问时间。 |
2 | File::basename( path[, suffix]) 返回path末尾的文件名。如果指定了suffix,则将其从文件名的末尾删除。 例如 File.basename("/home/users/bin/ruby.exe") #=> "ruby.exe" |
3 | File::blockdev?( path) 如果path是块设备,则返回true。 |
4 | File::chardev?( path) 如果path是字符设备,则返回true。 |
5 | File::chmod( mode, path...) 更改指定文件的权限模式。 |
6 | File::chown( owner, group, path...) 更改指定文件的拥有者和组。 |
7 | File::ctime( path) 返回path的最后节点更改时间。 |
8 | File::delete( path...) File::unlink( path...) 删除指定的文件。 |
9 | File::directory?( path) 如果path是目录,则返回true。 |
10 | File::dirname( path) 返回path的目录部分,不包括最终的文件名。 |
11 | File::executable?( path) 如果path可执行,则返回true。 |
12 | File::executable_real?( path) 如果path使用真实用户权限可执行,则返回true。 |
13 | File::exist?( path) 如果path存在,则返回true。 |
14 | File::expand_path( path[, dir]) 返回path的绝对路径,将~扩展到进程所有者的主目录,并将~user扩展到用户的主目录。相对路径从dir指定的目录或省略dir时的当前工作目录解析。 |
15 | File::file?( path) 如果path是普通文件,则返回true。 |
16 | File::ftype( path) 返回以下字符串之一,表示文件类型: file - 普通文件 directory - 目录 characterSpecial - 字符特殊文件 blockSpecial - 块特殊文件 fifo - 命名管道 (FIFO) link - 符号链接 socket - 套接字 unknown - 未知文件类型 |
17 | File::grpowned?( path) 如果path由用户的组拥有,则返回true。 |
18 | File::join( item...) 返回一个字符串,该字符串由指定项连接在一起,每个项之间用File::Separator分隔。 例如 File::join("", "home", "usrs", "bin") # => "/home/usrs/bin" |
19 | File::link( old, new) 创建到文件old的硬链接。 |
20 | File::lstat( path) 与stat相同,但它返回符号链接本身的信息,而不是它们指向的文件的信息。 |
21 | File::mtime( path) 返回path的最后修改时间。 |
22 | File::new( path[, mode = "r"]) File::open( path[, mode = "r"]) File::open( path[, mode = "r"]) {|f| ...} 打开一个文件。如果指定了块,则该块将使用作为参数传递的新文件执行。当块退出时,文件会自动关闭。即使path以|开头,这些方法也与Kernel.open不同,后面的字符串不会作为命令运行。 |
23 | File::owned?( path) 如果path由有效用户拥有,则返回true。 |
24 | File::pipe?( path) 如果path是管道,则返回true。 |
25 | File::readable?( path) 如果path可读,则返回true。 |
26 | File::readable_real?( path) 如果path使用真实用户权限可读,则返回true。 |
27 | File::readlink( path) 返回path指向的文件。 |
28 | File::rename( old, new) 将文件名从old更改为new。 |
29 | File::setgid?( path) 如果path的set-group-id权限位已设置,则返回true。 |
30 | File::setuid?( path) 如果path的set-user-id权限位已设置,则返回true。 |
31 | File::size( path) 返回path的文件大小。 |
32 | File::size?( path) 返回path的文件大小,如果为0则返回nil。 |
33 | File::socket?( path) 如果path是套接字,则返回true。 |
34 | File::split( path) 返回一个数组,其中包含path的内容,分成File::dirname(path)和File::basename(path)。 |
35 | File::stat( path) 返回一个File::Stat对象,其中包含path的信息。 |
36 | File::sticky?( path) 如果path的粘滞位已设置,则返回true。 |
37 | File::symlink( old, new) 创建到文件old的符号链接。 |
38 | File::symlink?( path) 如果path是符号链接,则返回true。 |
39 | File::truncate( path, len) 将指定文件截断为len字节。 |
40 | File::unlink( path...) 删除给定路径的文件。 |
41 | File::umask([ mask]) 如果未指定参数,则返回此进程的当前umask。如果指定了参数,则设置umask,并返回旧的umask。 |
42 | File::utime( atime, mtime, path...) 更改指定文件的访问和修改时间。 |
43 | File::writable?( path) 如果path可写,则返回true。 |
44 | File::writable_real?( path) 如果path使用真实用户权限可写,则返回true。 |
45 | File::zero?( path) 如果path的文件大小为0,则返回true。 |
实例方法
假设f是File类的实例:
序号 | 方法和描述 |
---|---|
1 | f.atime 返回f的最后访问时间。 |
2 | f.chmode( mode) 更改f的权限模式。 |
3 | f.chown( owner, group) 更改f的拥有者和组。 |
4 | f.ctime 返回f的最后inode更改时间。 |
5 | f.flock( op) 调用flock(2)。op可以是0或File类常量LOCK_EX、LOCK_NB、LOCK_SH和LOCK_UN的逻辑或。 |
6 | f.lstat 与stat相同,但它返回符号链接本身的信息,而不是它们指向的文件的信息。 |
7 | f.mtime 返回f的最后修改时间。 |
8 | f.path 返回用于创建f的文件路径名。 |
9 | f.reopen( path[, mode = "r"]) 重新打开文件。 |
10 | f.truncate( len) 将f截断为len字节。 |