Linux 文件和目录操作命令(一)

1、cd

(change directory)切换到指定目录

-       返回上次目录
..      返回上层目录
回车    返回主目录
/       根目录

2、cp

(copy)复制文件或目录

-r -R 递归复制该目录及其子目录内容
-p  连同档案属性一起复制过去
-f  不询问而强制复制
-s  生成快捷方式
-a  将档案的所有特性都一起复制

cp -r /home/hj/a    /tmp

3、find

查找目录及目录下的文件

选项与参数:
1. 与时间有关的选项:共有 -atime, -ctime 与 -mtime 和-amin,-cmin与-mmin,以 -mtime 说明
   -mtime n :n 为数字,意义为在 n 天之前的『一天之内』被更动过内容的档案;
   -mtime +n :列出在 n 天之前(不含 n 天本身)被更动过内容的档案档名;
   -mtime -n :列出在 n 天之内(含 n 天本身)被更动过内容的档案档名。
   -newer file :file 为一个存在的档案,列出比 file 还要新的档案档名

2. 与使用者或组名有关的参数:
   -uid n :n 为数字,这个数字是用户的账号 ID,亦即 UID
   -gid n :n 为数字,这个数字是组名的 ID,亦即 GID
   -user name :name 为使用者账号名称!例如 dmtsai
   -group name:name 为组名,例如 users ;
   -nouser :寻找档案的拥有者不存在 /etc/passwd 的人!
   -nogroup :寻找档案的拥有群组不存在于 /etc/group 的档案!

3. 与档案权限及名称有关的参数:
   -name filename:搜寻文件名为 filename 的档案(可使用通配符)
   -size [+-]SIZE:搜寻比 SIZE 还要大(+)或小(-)的档案。这个 SIZE 的规格有:
       c: 代表 byte
       k: 代表 1024bytes。所以,要找比 50KB还要大的档案,就是『 -size +50k 』
   -type TYPE :搜寻档案的类型为 TYPE 的,类型主要有:
       一般正规档案 (f)
       装置档案 (b, c)
       目录 (d)
       连结档 (l)
       socket (s)
       FIFO (p)
   -perm mode :搜寻档案权限『刚好等于』 mode的档案,这个mode为类似chmod的属性值,举例来说,-rwsr-xr-x 的属性为4755!
   -perm -mode :搜寻档案权限『必须要全部囊括 mode 的权限』的档案,举例来说,
       我们要搜寻-rwxr--r-- 亦即 0744 的档案,使用-perm -0744,当一个档案的权限为 -rwsr-xr-x ,亦即 4755 时,也会被列出来,因为 -rwsr-xr-x 的属性已经囊括了 -rwxr--r-- 的属性了。
   -perm +mode :搜寻档案权限『包含任一 mode 的权限』的档案,举例来
       说,我们搜寻-rwxr-xr-x ,亦即 -perm +755 时,但一个文件属性为 -rw-------也会被列出来,因为他有 -rw.... 的属性存在!
4. 额外可进行的动作:
   -exec command :command 为其他指令,-exec 后面可再接额外的指令来处理搜寻到的结果。
   -print :将结果打印到屏幕上,这个动作是预设动作!
   eg:
       find / -perm +7000 -exec ls -l {} ; ,额外指令以-exec开头,以;结尾{}代替前面找到的内容
   | xargs 
       -i  默认的前面输出用{}代替 
       eg:
           find . -name "*.log" | xargs -i mv {} test4

示例:

# 按文件名查找
# 查找 /etc 目录下所有 passwd
find /etc/ -name passwd

# 按查找深度
root@dly-virtual-machine:/home/dly# find /etc -maxdepth 1 -name passwd
/etc/passwd

root@dly-virtual-machine:/home/dly# find /etc -maxdepth 2 -name passwd
/etc/cron.daily/passwd
/etc/pam.d/passwd
/etc/passwd

# 按文件大小
root@dly-virtual-machine:/home/dly# find /mnt -size 20k
root@dly-virtual-machine:/home/dly# find /mnt -size -20k    # 小于 20k
/mnt
root@dly-virtual-machine:/home/dly# find /mnt -size +20k    # 大于 20k

# 按文件类型
find /dev -type f   # 普通文件
find /dev -type b   # 块设备
find /dev -type s   # 套接字
find /dev -type p   # 管道
find /dev -type d   # 目录

# 按权限查找

##查找文件权限为404的文件
[root@localhost mnt]# find /mnt -perm 404
/mnt/file2

##查看文件权限中u位有r权限,并且o位有r权限的文件
[root@localhost mnt]# find /mnt -perm -404
/mnt
/mnt/file1
/mnt/file2

##查看文件权限中u位有r权限,或者o位有r权限的文件
[root@localhost mnt]# find /mnt -perm /404

4、mkdir

(make directory)创建文件夹

-p  递归创建目录,若父目录不存在则依次创建
-m  自定义创建目录的权限  eg:mkdir -m 777 hehe
-v  显示创建目录的详细信息

5、mv

(move)移动或重命名文件(重命名时会删除源文件,cp 不会)

-b  覆盖前做备份
-f  如存在不询问而强制覆盖
-i  如存在则询问是否覆盖
-u  较新才覆盖
-t  将多个源文件移动到统一目录下,目录参数在前,文件参数在后

eg:
   mv a /tmp/ 将文件a移动到 /tmp目录下
   mv a b 将a命名为b
   mv /home/zenghao test1.txt test2.txt test3.txt

6、pwd

(print working directory)显示当前工作目录的绝对路径。

7、rename

重命名文件

Usage:rename [-v] [-n] [-f] perlexpr [filenames]

-v(verbose)     打印被成功重命名的文件
-n(no-act)      只显示将被重命名的文件,而非实际进行重命名操作
-f(force)       覆盖已经存在的文件
perlexprPerl语言格式的正则表达式
files需要被替换的文件(比如*.c、*.h),如果没给出文件名,将从标准输入读

【常用通配符说明】
 ?    表示一个任意字符
 *    表示一个或一串任意字符
-------------------------------------------------
【常用正则表达式符号说明】
^    匹配输入的开始位置
$    匹配输入的结尾
.    匹配除换行符外的任意字符
+    匹配前一个字符一次或多次 例如,"zo+"可以匹配"zoo",但不匹配"z"
[a-z]    表示某个范围内的字符,例如,"[a-z]"匹配"a"与"z"之间的任何一个小写字母字符。
[^m-z]    否定的字符区间。与不在指定区间内的字符匹配。

示例:


[root@localhost www]# rename 's/.sh/.php/' *        #将当前目录下.sh后缀的文件,变成.php

[root@localhost www]# rename 's/$/.bak/' /home/www/*.php     #给www目录下的.php加上bak后缀

[root@localhost www]# rename 's/^/bak_/' *.bin     #给当前目录下的.bin后缀文件加上bak_前缀

[root@localhost www]# rename 's/.bin$//' *       #批量删除当前目录下所有文件的.bin 后缀

[root@localhost www]# rename 's/A-Z/a-z/' *       #修改当前目录所有文件名为小写

8、rm

(remove)删除一个或多个文件或目录

-r  删除文件夹
-f  删除不提示
-i  删除提示
-v  详细显示进行步骤

9、rmdir

(remove empty directories)删除空目录

-v  显示执行过程
-p  若自父母删除后父目录为空则一并删除

10、touch

创建新的空文件,改变已有文件的时间戳属性

-a  只修改存取时间
-m  值修改变动时间
-r  eg:touch -r a b ,使b的时间和a相同
-t  指定特定的时间 eg:touch -t 201211142234.50 log.log 
   -t time [[CC]YY]MMDDhhmm[.SS],C:年前两位

eg:
touch a.txt     # 新建文件 a.txt

11、tree

以树形结构显示目录下的内容

-a 显示所有文件和目录。
-A 使用ASNI绘图字符显示树状图而非以ASCII字符组合。
-C 在文件和目录清单加上色彩,便于区分各种类型。
-d 显示目录名称而非内容。
-D 列出文件或目录的更改时间。
-f 在每个文件或目录之前,显示完整的相对路径名称。
-F 在执行文件,目录,Socket,符号连接,管道名称名称,各自加上"*","/","=","@","|"号。
-g 列出文件或目录的所属群组名称,没有对应的名称时,则显示群组识别码。
-i 不以阶梯状列出文件或目录名称。
-I<范本样式> 不显示符合范本样式的文件或目录名称。
-l 如遇到性质为符号连接的目录,直接列出该连接所指向的原始目录。
-n 不在文件和目录清单加上色彩。
-N 直接列出文件和目录名称,包括控制字符。
-p 列出权限标示。
-P<范本样式> 只显示符合范本样式的文件或目录名称。
-q 用"?"号取代控制字符,列出文件和目录名称。
-s 列出文件或目录大小。
-t 用文件和目录的更改时间排序。
-u 列出文件或目录的拥有者名称,没有对应的名称时,则显示用户识别码。
-x 将范围局限在现行的文件系统中,若指定目录下的某些子目录,其存放于另一个文件系统上,则将该子目录予以排除在寻找范围外。
-L 等级/深度

eg:
tree /home/dly -L 1     # 深度为 1
tree -a     # 显示所有文件和目录

12、basename

获取路径中的文件名或路径名

# 获取末尾的文件名或路径名
$ basename /etc/passwd
passwd
$ basename /etc/man.config
man.config
$ basename /etc
etc

# 去掉末尾的指定字符,第二个参数指定后缀名即可
$ basename /etc/man.config
man.config
$ basename /etc/man.config .config
man

# 取消指定字符
$ basename namedb.data db.data

13、dirname

显示指定路径除了文件名之外的路径前缀

dirname /usr/bin/          -> "/usr"
dirname dir1/str dir2/str  -> "dir1" followed by "dir2"
dirname stdio.h            -> "."

14、chattr、lsattr

改变(查看)文件的拓展属性

root@dly-virtual-machine:/home/dly/test# lsattr a.txt 
-------------e-- a.txt

# #设置该文件不能进行任何形势的修改
root@dly-virtual-machine:/home/dly/test# chattr +i a.txt 
root@dly-virtual-machine:/home/dly/test# lsattr a.txt 
----i--------e-- a.txt

chattr -i nginx.conf                    #取消-i的权限设置

chattr +a /var/log/messages   #让某个文件只能往里面追加数据,但不能删除

15、file

显示文件类型

-b
    不输出文件名 (简要模式).
-c
    检查时打印输出幻数文件的解析结果.常与 -m 一起使用,用来在安装幻数文件之前调试它.
-f 命名文件
    从在参数表前的 命名文件 中读出将要检查的文件名(每行一个文件).要有 命名文件 ,或者至少有一个文件名参数; 如果要检查标准输入, 使用``-作为文件参数.
-m list
    指定包含幻数的文件列表.可以是单个文件,也可以是 用冒号分开的多个文件.
-n
    每检查完一个文件就强制刷新标准输出. 仅在检查一组文件时才有效. 一般在将文件类型输出到管道时才采用此选项.
-v
    打印程序版本并退出.
-z
    试图查看压缩文件内部信息.
-L
    (在支持符号链接的系统上)选项显示符号链接文件的原文件, 就像 ls(1) 命令的like-named 选项.
-s
    通常, file 只是试图去检查在文件列表中那些 stat(2) 报告为正常文件的文件的类型.由于读特殊文件将可能导致 不可知后果,所以这样可以防止发生问题.使用 -s 选项时 file 命令也将去读文件列表中的块特殊文件和字符特殊文件. 一般用于从原始磁盘分区中获得文件系统类型,此文件为块 特殊文件. 这个选项也导致 file 命令忽略 stat(2) 报告的文件大小,因为在有些系统中原始磁盘分区的大小报告为0.

示例:

$ file *        # 查看当前文件的类型
$ file a.txt    # 查看单个文件的类型
$ file -z test.bz2  # 查看压缩文件中的文件类型

16、md5sum

计算和校验文件的 MD5 值

用法:md5sum [选项]... [文件]...
显示或检查 MD5(128-bit) 校验和。
若没有文件选项,或者文件处为"-",则从标准输入读取。

  -b, --binary          以二进制模式读取
  -c, --check           从文件中读取MD5 的校验值并予以检查
  -t, --text            以纯文本模式读取(默认)

以下三个选项在进行校验时非常有用:
      --quiet           不为校验成功的文件输出OK
      --status          不输出任何内容,使用退出状态号显示成功
  -w, --warn            对格式不准确的校验和行进行警告

      --strict         with --check, exit non-zero for any invalid input
      --help            显示此帮助信息并退出
      --version         显示版本信息并退出

校验和会按照RFC 1321 规范生成。当进行检查时,给出的输入格式应该和程序的输出
样板格式相同。默认的输出模式时输出一行校验和的校验结果,并有一个字符来
表示文件类型("*"代表二进制," "代表纯文本),并同时显示每个文件的名称

示例:

# 以二进制形式显示 md5
root@dly-virtual-machine:/home/dly/test# md5sum -b a.txt 
d41d8cd98f00b204e9800998ecf8427e *a.txt

# 生成md5加密检验和    
root@dly-virtual-machine:/home/dly/test# md5sum a.txt > a.md5
root@dly-virtual-machine:/home/dly/test# ls
1.jpg  2.jpg  a  a.md5  a.txt
root@dly-virtual-machine:/home/dly/test# cat a.md5 
d41d8cd98f00b204e9800998ecf8427e  a.txt

# 检验与文件是否一致
root@dly-virtual-machine:/home/dly/test# md5sum -c a.md5 
a.txt: 确定