• CentOS(九)--与Linux文件和目录管理相关的一些重要命令①


       接上一篇文章,实际生产过程中的目录管理一定要注意用户是root 还是其他用户。

    一、目录与路径

    1.相对路径与绝对路径

    因为我们在Linux系统中,常常要涉及到目录的切换,所以我们必须要了解 "路径" 以及 "相对路径" 与 "绝对路径" 的概念。

    在之前的学习中,就反复的强调了Linux的目录是 "树状目录" 。假设我们需要在任意一个目录下切换到另一个目录下,通常是使用的是 cd 这个命令,此时在写切换的目录名时就有两种书写方式,也就是我们常说的使用 "相对路径" 与 "绝对路径" 来书写

    • 绝对路径:路径的写法【一定由根目录 / 写起】,例如: /usr/share/doc 这个目录。
    • 相对路径:路径的写法【不是由 / 写起】,例如由 /usr/share/doc 要到 /usr/share/man 底下时,可以写成: 【cd ../man】这就是相对路径的写法。相对路径意指相对于当前的工作目录

    我们知道,在Linux的系统中完整的文件路径名的长度最大可以达到4096个字符,所以一个文件路径名太长的话,此时写绝对路径时就非常的麻烦,而且可能写错,所以此时选择使用相对路径来写就会简单一些。

    但是,对于文件的正确性来说,绝对路径是比较好的。当我们在写 shell scripts 时,请务必使用绝对路径。虽然可能写绝对路径会稍显麻烦,但是这种写法是绝对不会有问题的。

    2.cd (切换目录)

    这个命令应该是Linux中用的最频繁的一个命令之一了,因为我们经常需要进行目录的切换。在详解这个命令之前,首先得补充一个重要的知识,就是我们常用的一些比较特殊的目录:

    .         代表当前目录
    ..        代表上一层目录
    -         代表前一个工作目录
    ~         代表【目前用户身份】所在的自家目录
    ~account  代表 account 这个用户的自家家目录

    我们通过实例来看一下这些特殊命令的使用方法:

    复制代码
    [root@xiaoluo ~]# cd /home
    #    此时我们进入到了home目录下
    [root@xiaoluo home]# cd .
    #    .表示当前目录,所以当前还是在home目录下
    [root@xiaoluo home]# cd ..
    #    ..表示上一层目录,所以此时就进入到了 / 目录下
    [root@xiaoluo /]# cd ~
    #   ~表示【目前用户身份】所在的自家目录,当前用户就是root,所以就进入到了root这个目录下
    [root@xiaoluo ~]# cd ~xiaoluo
    #   ~account表示 account 这个用户的自家家目录 ,我如果想进入 xiaoluo 这个用户的主目录,输入 cd ~xiaoluo即可
    [root@xiaoluo xiaoluo]# cd -
    /root
    #   -表示前一个工作目录,我们的前一个工作目录就是在root下,所以此时又会进入到root这个目录下
    [root@xiaoluo ~]# cd ../usr
    #   如果我们需要进入到usr目录下,这里可以写成相对路径形式也可以写成绝对路径形式
    [root@xiaoluo usr]#
    复制代码

    通过上面的几个实例我们应该对cd 这个命令有了深入的了解了,而且也知道了那几个特殊目录所代表的含义。

    3.pwd (显示当前所在的目录)

    这个命令对于我们来说也是一个很重要的命令,因为在Linux下我们都是通过在命令行输入命令,所有如果进入到了一个目录下,就不会像windows那样直观的显示出当前所在的路径,此时我们就可以输入 pwd 这个命令来显示我们当前所在的目录。

    复制代码
    [root@xiaoluo ~]# pwd [-P]
    参数:
    -P  :显示出确实的路径,而非使用链接 (link) 路径。(P是大写)
    范例: [root@xiaoluo ~]# pwd /root <== 显示出当前所在的目录
    [root@xiaoluo ~]# cd /var/mail [root@xiaoluo mail]# pwd /var/mail [root@xiaoluo mail]# pwd -P /var/spool/mail <== 怎么回事?有没有加 -P 差很多
    [root@xiaoluo mail]# ls -l /var/mail lrwxrwxrwx. 1 root root 10 3月 30 10:37 mail -> spool/mail # 看到这里应该知道为啥了吧?因为 /var/mail 是连结文件,连结到 /var/spool/mail # 所以,加上 pwd -P 的参数后,会不以连结文件的数据显示,而是显示正确的完整路径!
    复制代码

    4.mkdir (建立新目录)

    复制代码
    [root@xiaoluo ~]# mkdir [-mp] 目录名称
    参数:
    -m :配置文件目录的权限!我们可以自己设定自己想要的权限,而不需要使用umask定义的默认权限
    -p :帮助你直接将所需要的目录递归建立起来!
    范例:
    [root@xiaoluo ~]# cd /home
    [root@xiaoluo home]# mkdir test    <== 建立一名为 test 的新目录
    [root@xiaoluo home]# mkdir test1/test2/test3/test4
    mkdir: 无法创建目录"test1/test2/test3/test4": 没有那个文件或目录
    [root@linux tmp]# mkdir -p test1/test2/test3/test4 # 加了这个 -p 的参数,可以自行帮我们建立多层目录! [root@xiaoluo home]# mkdir -p test1/test2/test3/test4 [root@xiaoluo home]# mkdir -m 711 test2 [root@xiaoluo home]# ls -l drwxr-xr-x. 2 root root 4096 4月 21 13:08 test drwxr-xr-x. 3 root root 4096 4月 21 13:10 test1 drwx--x--x. 2 root root 4096 4月 21 13:11 test2 # 仔细看上面的权限部分,如果没有加上 -m 来强制设定属性,系统会使用默认属性。如果加上了-m 这个参数,我们就可以自己定义权限了
    复制代码

    5.rmdir (删除"空"目录)

    复制代码
    [root@xiaoluo ~]# rmdir [-p] 目录名称
    参数:
    -p :连同上层『空的』目录也一起删除
    范例:
    [root@xiaoluo home]# ls -l
    drwxr-xr-x.  2 root    root         4096 4月  21 13:08 test
    drwxr-xr-x.  3 root    root         4096 4月  21 13:10 test1
    drwx--x--x.  2 root    root         4096 4月  21 13:11 test2
    [root@xiaoluo home]# rmdir test
    [root@xiaoluo home]# rmdir test1
    rmdir: 删除 "test1" 失败: 目录非空
    [root@xiaoluo home]# rmdir -p test1/test2/test3/test4/
    [root@xiaoluo home]# ls -l
    drwx--x--x.  2 root    root         4096 4月  21 13:11 test2
    
    # 利用 -p 这个参数,立刻就可以将 test1/test2/test3/test4 一次删除~ # 不过要注意的是,这个 rmdir 仅能【删除空的目录】!
    复制代码

    二、管理文件与目录
    在了解目录与路径之后,我们继续学习管理文件与目录的一些命令!文件与目录的管理上,不外乎【显示属性】、【拷贝】、【删除文件】及【移动文件或目录』】等等,由于文件与目录的管理在 Linux 当中是很重要的, 尤其是每个人自己自家目录的数据也都需要注意管理!

    1.ls (查看文件和目录)

    复制代码
    [root@xiaoluo ~]# ls [-aAdfFhilRS] 目录名称
    [root@xiaoluo ~]# ls [--color={none,auto,always}] 目录名称
    [root@xiaoluo ~]# ls [--full-time] 目录名称
    参数:
    -a  :全部的文件,连同隐藏文件( 开头为 . 的目录) 一起列出来~
    -A  :全部的文件,连同隐藏文件,但不包括 . 与 .. 这两个目录,一起列出来~
    -d  :仅列出目录本身,而不是列出目录内的文件数据
    -f  :直接列出结果,而不进行排序 (ls 预设会以文件名排序!)
    -F  :根据文件、目录等信息,给予附加数据结构,例如:
          *:代表可执行文件; /:代表目录; =:代表 socket 档案; |:代表 FIFO 文件;
    -h  :列出文件的打小(例如GB、KB等等)
    -i  :列出 inode 位置,而非列出文件属性;
    -l  :长数据串行出,包含文件的属性等等数据;
    -n  :列出 UID 与 GID 而非使用者与群组的名称 (UID与GID会在账号管理提到!)
    -r  :将排序结果反向输出,例如:原本文件名由小到大,反向则为由大到小;
    -R  :连同子目录内容一起列出来;
    -S  :以文件容量大小排序!
    -t  :依时间排序
    --color=never  :不要依据文件特性给予颜色显示;
    --color=always :显示颜色
    --color=auto   :让系统自行依据设定来判断是否给予颜色
    --full-time    :以完整时间模式 (包含年、月、日、时、分) 输出
    --time={atime,ctime} :输出 access 时间或 改变权限属性时间 (ctime) 
                           而非内容变更时间 (modification time)
    复制代码

    在 Linux 系统当中,这个 ls 指令可能是最常被执行的命令!因为我们随时都要知道文件或者是目录的相关信息啊。 不过,我们 Linux 的文件所记录的信息实在是太多了, ls 没有需要全部都列出来呢, 所以,当输入ls命令时,默认显示的只有:非隐藏文件的文件名、 以文件名进行排序及文件名代表的颜色显示;

    复制代码
    [root@xiaoluo home]# ls -al ~
    总用量 216
    dr-xr-x---. 31 root root  4096 4月  19 20:40 .
    dr-xr-xr-x. 26 root root  4096 4月  21 11:14 ..
    drwxr-xr-x.  2 root root  4096 3月  31 14:26 .abrt
    -rw-------.  1 root root 13062 4月  21 00:58 .bash_history
    -rw-r--r--.  1 root root    18 5月  20 2009 .bash_logout
    -rw-r--r--.  1 root root   176 5月  20 2009 .bash_profile
    -rw-r--r--.  1 root root   177 4月   8 22:43 .bashrc
    drwxr-xr-x.  4 root root  4096 4月   1 12:28 .cache
    drwxr-xr-x.  6 root root  4096 4月   1 12:26 .config
    -rw-r--r--.  1 root root   100 9月  23 2004 .cshrc
    drwx------.  3 root root  4096 3月  31 14:25 .dbus
    -rw-------.  1 root root    16 3月  31 14:26 .esd_auth
    drwx------.  4 root root  4096 4月   5 12:09 .gconf
    drwx------.  2 root root  4096 4月   5 18:56 .gconfd
    drwx------.  7 root root  4096 4月   1 12:28 .gnome2
    drwx------.  2 root root  4096 4月   1 11:49 .gnome2_private
    drwxr-xr-x.  3 root root  4096 3月  31 14:26 .gnote
    drwx------.  2 root root  4096 4月   1 11:46 .gnupg
    drwxr-xr-x.  2 root root  4096 3月  31 14:26 .gstreamer-0.10
    -rw-r--r--.  1 root root   160 4月   1 11:46 .gtk-bookmarks
    drwx------.  2 root root  4096 3月  31 14:25 .gvfs
    -rw-------.  1 root root   624 4月   1 11:46 .ICEauthority
    -rw-r--r--.  1 root root   785 4月   1 11:46 .imsettings.log
    drwx------.  3 root root  4096 4月   1 12:26 .kde
    -rw-------.  1 root root    46 4月  20 23:50 .lesshst
    drwxr-xr-x.  3 root root  4096 3月  31 14:25 .local
    drwxr-xr-x.  4 root root  4096 4月   1 11:49 .mozilla
    -rw-------.  1 root root  1711 4月  19 20:23 .mysql_history
    drwxr-xr-x.  2 root root  4096 3月  31 14:26 .nautilus
    drwx------.  2 root root  4096 3月  31 14:26 .pulse
    -rw-------.  1 root root   256 3月  31 14:25 .pulse-cookie
    -rw-------.  1 root root  3244 4月   1 12:34 .recently-used.xbel
    drwxr-xr-x.  3 root root  4096 3月  31 14:26 .redhat
    drwx------.  2 root root  4096 3月  31 14:25 .ssh
    drwxr-xr-x.  2 root root  4096 3月  30 11:20 .targetcli
    -rw-r--r--.  1 root root   129 12月  4 2004 .tcshrc
    drwx------.  3 root root  4096 4月   1 12:18 .thumbnails
    -rw-------.  1 root root   511 4月   5 00:04 .viminfo
    -rw-------.  1 root root    52 3月  31 14:18 .xauth58xele
    -rw-------.  1 root root    52 4月  19 19:34 .xauthAQSudj
    -rw-------.  1 root root    52 4月   1 20:09 .xauthFR3WoT
    -rw-------.  1 root root    52 3月  31 21:56 .xauthGPcuIJ
    -rw-------.  1 root root    52 3月  31 22:06 .xauthhgV2Ad
    -rw-------.  1 root root     0 3月  30 15:26 .Xauthority
    复制代码

    2. cp (复制命令)
    要复制文件,我们就要用到cp(copy)命令。不过cp命令的用途非常的广泛,除了单纯的复制之外,还可以建立连接文件(相当于windows下的快捷方式),比较两个文件的新旧而予以更新,以及复制整个目录等等。

    复制代码
    [root@xiaoluo ~]# cp [-adfilprsu] 源文件(source) 目的文件(destination)
    [root@xiaoluo ~]# cp [options] source1 source2 source3 .... directory
    参数:
    -a  :相当于 -pdr 的意思;
    -d  :若来源文件为链接文件的属性(link file),则复制链接文件属性而非档案本身;
    -f  :为强制 (force) 的意思,若有重复或其他疑问时,不会询问使用者,而强制复制;
    -i  :若目的文件(destination)已经存在时,在覆盖时会先询问是否真的动作!
    -l  :进行硬式连结 (hard link) 的连结文件建立,而非复制文件本身;
    -p  :连同文件的属性一起复制过去,而非使用默认属性;
    -r  :递归持续复制,用于目录的复制行为;
    -s  :复制成为符号链接文件 (symbolic link),亦即『快捷方式』文件;
    -u  :若 destination 比 source 旧才更新 destination !
    最后需要注意的,如果来源档有两个以上,则最后一个目的文件一定要是『目录』
    复制代码

    下面我们来写一些实例来看一下cp命令的常用用法:

    复制代码
    实例一:将家目录下的 .bashrc 复制到 /tmp 下,并更名为 bashrc
    [root@xiaoluo home]# cd /tmp
    [root@xiaoluo tmp]# cp ~/.bashrc bashrc
    [root@xiaoluo tmp]# cp -i ~/.bashrc bashrc 
    cp:是否覆盖"bashrc"? n
    
    # 重复作两次动作,由于 /tmp 底下已经存在 bashrc 了,加上 -i 参数,
    # 则在覆盖前会询问使用者是否确定!可以按下 n 或者 y !
    # 但是,反过来说,如果不想要询问时,则加上 -f 这个参数来强制直接覆盖!
    
    实例二:将 /var/log/wtmp 复制到 /tmp 底下
    [root@xiaoluo tmp]# cp /var/log/wtmp .
    [root@xiaoluo tmp]# ls -l /var/log/wtmp wtmp 
    -rw-rw-r--. 1 root utmp 204288 4月  21 11:22 /var/log/wtmp
    -rw-r--r--. 1 root root 204288 4月  21 13:33 wtmp
    
    # 注意到了吗?!在不加任何参数的情况下,文件的所属者会改变,连权限也跟着改变了
    # 这是个很重要的特性!要注意!还有,连文件建立的时间也不一样了! # 如果您想要将文件的所有特性都一起复制过来,可以加上 -a 参数即可!

    [root@xiaoluo tmp]# cp -a /var/log/wtmp wtmp2
    [root@xiaoluo tmp]# ls -l /var/log/wtmp wtmp2
    -rw-rw-r--. 1 root utmp 204288 4月  21 11:22 /var/log/wtmp
    -rw-rw-r--. 1 root utmp 204288 4月  21 11:22 wtmp2
    # 此时我们看到在加上 -a 这个参数以后,文件的所有属性都会被复制过来。

    实例三:复制 /etc/ 这个目录下的所有内容到 /tmp 底下
    [root@xiaoluo tmp]# cp /etc/ /tmp
    cp: 略过目录"/etc/"    -->> 如果我们复制的是目录,此时必须要加上 -r 这个参数才行
    [root@xiaoluo tmp]# cp -r /etc/ /tmp
    # 还是要再次的强调! -r 是可以复制目录,但是,档案与目录的权限会被改变
    # 所以,也可以利用 cp -a /etc /tmp 来下达指令!    使用-a 参数相当于同时使用了 -pdr 参数
    复制代码

    3.rm (删除文件或目录)

    [root@xiaoluo ~]# rm [-fir] 文件或目录
    参数:
    -f  :就是 force 的意思,强制移除;
    -i  :互动模式,在删除前会询问使用者是否动作
    -r  :递归删除!最常用在目录的删除了

    下面我们通过一些实例来看一下rm命令的使用

    复制代码
    [root@xiaoluo tmp]# rm bashrc 
    rm:是否删除普通文件 "bashrc"?y
    [root@xiaoluo tmp]# rm wtmp wtmp2
    rm:是否删除普通文件 "wtmp"?y
    rm:是否删除普通文件 "wtmp2"?y

    [root@xiaoluo tmp]# rm -rf etc/  -->> 这个就会强制将etc这个目录以及里面的所有子目录、文件删除掉
    复制代码

    4.mv (移动文件与目录、文件重命名)

    复制代码
    [root@xiaoluo ~]# mv [-fiu] source destination
    [root@xiaoluo ~]# mv [options] source1 source2 source3 .... directory
    参数:
    -f  :force 强制的意思,强制直接移动而不询问;
    -i  :若目标文件 (destination) 已经存在时,就会询问是否覆盖!
    -u  :若目标文件已经存在,且 source 比较新,才会更新 (update)

    实例一:复制一档案,建立一目录,将档案移动到目录中
    [root@xiaoluo tmp]# cp ~/.bashrc bashrc
    [root@xiaoluo tmp]# mkdir mvtest
    [root@xiaoluo tmp]# mv bashrc mvtest/
    [root@xiaoluo tmp]# cd mvtest/
    [root@xiaoluo mvtest]# ls
    bashrc
    # 将某个档案移动到某个目录去,就是这样做!

    实例二:将刚刚的目录名称更名为 mvtest2
    [root@xiaoluo tmp]# mv mvtest mvtest2  <== 这样就更名了!
    # 其实在 Linux 底下还有个命令令,名称为 rename ,
    # 该命令就是专门用来对文件或者目录进行重命名的镇明路!可以参阅 man rename 了解其更多的用法 !
    复制代码

    5.basename (获取路径的文件名) dirname (获取路径的目录名)
    完整的文件名最长我们可以为4096个字符。那么我们怎么样知道哪个代表的是文件名?哪个代表的是目录名呢?其实我们通过斜线 / 就可以来分辨。当然Linux下的basename、dirname这两个命令也可以帮助我们来获得文件名和目录名。例如:

    [root@xiaoluo ~]# basename /etc/inittab 
    inittab  -->>这个就是我们的文件名
    [root@xiaoluo ~]# dirname /etc/inittab /etc    -->>这个就是我们的目录名

    三、查看文件内容

    上面提到的一些命令例如ls 只是用来显示文件的属性与权限,或者移动与复制文件或目录,那么我们如果想要查看文件里面的内容,又有哪些命令可以使用呢?

    • cat   由第一行开始显示文件内容
    • tac   从最后一行开始显示,可以看出 tac 是 cat 的倒着写!
    • nl   显示的时候,连同行号一起输出!
    • more 一页一页的显示文件内容
    • less 与 more 类似,但是比 more 更好的是,他可以往前翻页!
    • head 只看头几行
    • tail 只看最后几行
    • od     以二进制的方式读取文件内容!

    我们最常用的显示文件内容的命令是cat、more以及less,这三个我们用的最多。

    1.cat (concatenate)

    复制代码
    [root@xiaoluo~]# cat [-AEnTv]
    参数:
    -A  :相当于 -vET 的整合参数,可列出一些特殊字符~
    -E  :将结尾的断行字符 $ 显示出来;
    -n  :打印出行号;
    -T  :将 [tab] 按键以 ^I 显示出来;
    -v  :列出一些看不出来的特殊字符
    复制代码

    我们通过实例来看一下cat命令的常用使用方法:

    复制代码
    [root@xiaoluo ~]# cat /etc/sysconfig/network
    NETWORKING=yes
    HOSTNAME=xiaoluo

    [root@xiaoluo ~]# cat -n /etc/sysconfig/network
         1  NETWORKING=yes
         2  HOSTNAME=xiaoluo

    [root@xiaoluo ~]# cat -A /etc/sysconfig/network
    NETWORKING=yes$
    HOSTNAME=xiaoluo$

    # 在一般的环境中,打印出来的结果在有 [tab] 与空格键,其实看不出来,
    # 那么使用 cat -A 时,会将 [tab] 按键以 ^I 显示,而断行字符也会显示出来
    # 最特殊的当然就是断行字符了!这个段行字符在 Linux 与 Windows 是不一样的。
    # 在 Linux 是以 $ 为断行字符,而在 Windows 则是以 ^M$ 为断行字符。
    复制代码

    2.tac (反向显示)

    [root@xiaoluo ~]# tac /etc/sysconfig/network
    HOSTNAME=xiaoluo
    NETWORKING=yes

    tac是将cat反写,所以它的功能就与cat相反, cat 是由【第一行到最后一行连续显示在屏幕上】,而 tac 则是『【由最后一行到第一行反向在屏幕上显示出来 】。

    3.nl (显示时添加行号)

    复制代码
    [root@xiaoluo ~]# nl [-bnw] 文件
    参数:
    -b  :指定行号指定的方式,主要有两种:
          -b a :表示不论是否为空行,也同样列出行号;
          -b t :如果有空行,空的那一行不要列出行号;
    -n  :列出行号表示的方法,主要有三种:
          -n ln :行号在屏幕的最左方显示;
          -n rn :行号在自己字段的最右方显示,且不加 0 ;
          -n rz :行号在自己字段的最右方显示,且加 0 ;
    -w  :行号字段的占用的位数。
    复制代码

    我们通过实例来看下nl命令的用法:

    复制代码
    [root@xiaoluo ~]# nl /etc/issue
         1  CentOS release 6.4 (Final)
         2  Kernel 
     on an m
    
    # 注意看,这个档案其实有三行,第三行为空白(没有任何字符),
    # 因为他是空白行,所以 nl 不会加上行号喔!如果确定要加上行号,可以这样做:
    
    [root@xiaoluo ~]# nl -b a /etc/issue
         1  CentOS release 6.4 (Final)
         2  Kernel 
     on an m
         3
    
    [root@xiaoluo ~]# nl -b a -n rz /etc/issue
    000001  CentOS release 6.4 (Final)
    000002  Kernel 
     on an m
    000003
    #  自动在自己字段的地方补上 0 了 预设字段是六位数,如果想要改成 3 位数 可以加上 -w 这个参数
    [root@xiaoluo ~]# nl -b a -n rz -w 3 /etc/issue 001 CentOS release 6.4 (Final) 002 Kernel on an m 003
    复制代码

    4.more (翻页查看)

    复制代码
    [root@xiaoluo ~]# more /etc/passwd
    root:x:0:0:root:/root:/bin/bash
    bin:x:1:1:bin:/bin:/sbin/nologin
    daemon:x:2:2:daemon:/sbin:/sbin/nologin
    adm:x:3:4:adm:/var/adm:/sbin/nologin
    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
    sync:x:5:0:sync:/sbin:/bin/sync
    shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
    halt:x:7:0:halt:/sbin:/sbin/halt
    mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
    uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
    operator:x:11:0:operator:/root:/sbin/nologin
    games:x:12:100:games:/usr/games:/sbin/nologin
    gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
    ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
    nobody:x:99:99:Nobody:/:/sbin/nologin
    dbus:x:81:81:System message bus:/:/sbin/nologin
    rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin
    usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
    abrt:x:173:173::/etc/abrt:/sbin/nologin
    pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin
    /nologin
    cimsrvr:x:134:134:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sb
    in/nologin
    --More--(36%)
    复制代码

    在使用more命令时,我们通常可以使用以下一些快捷键来帮助我们

    • 空格键 (space):代表向下翻一页;
    • Enter         :代表向下翻【一行】;
    • /字符串         :代表在这个显示的内容当中,向下搜寻【字符串】;
    • :f             :立刻显示出文件名以及目前显示的行数;
    • q             :代表立刻离开 more ,不再显示该文件内容。

    5. less (翻页查看)

    复制代码
    [root@xiaoluo ~]# less /etc/passwd
    root:x:0:0:root:/root:/bin/bash
    bin:x:1:1:bin:/bin:/sbin/nologin
    daemon:x:2:2:daemon:/sbin:/sbin/nologin
    adm:x:3:4:adm:/var/adm:/sbin/nologin
    lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
    sync:x:5:0:sync:/sbin:/bin/sync
    shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
    halt:x:7:0:halt:/sbin:/sbin/halt
    mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
    uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
    operator:x:11:0:operator:/root:/sbin/nologin
    games:x:12:100:games:/usr/games:/sbin/nologin
    gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
    ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
    nobody:x:99:99:Nobody:/:/sbin/nologin
    dbus:x:81:81:System message bus:/:/sbin/nologin
    rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin
    usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
    abrt:x:173:173::/etc/abrt:/sbin/nologin
    pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
    cimsrvr:x:134:134:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
    /etc/passwd 
    复制代码

    less的用法比more要更灵活,使用more命令时我们没有办法向前翻页,只能往后看,而less命令可以通过(PageUp) (PageDown)来进行前后的翻页查看文件。
    less命令的一些常用快捷键操作如下:

    • 空格键    :向下翻动一页;
    • [pagedown]:向下翻动一页;
    • [pageup]  :向上翻动一页;
    • /字符串     :向下搜寻【字符串】的功能;
    • ?字符串     :向上搜寻【字符串】的功能;
    • n         :重复前一个搜寻 (与 / 或 ? 有关!)
    • N         :反向的重复前一个搜寻 (与 / 或 ? 有关!)
    • q         :离开 less 这个程序;

    6. head (取出前几行)

    复制代码
    [root@xiaoluo ~]# head [-n number] 文件 
    参数:
    -n  :后面接数字,代表显示几行的意思
    
    实例: [root@xiaoluo ~]# head /etc/man.config # 默认的情况中,显示前面十行!若要显示前 20 行,就得要这样: [root@xiaoluo ~]# head -n 20 /etc/man.config
    复制代码

    7.tail (取出后面几行)

    复制代码
    [root@xiaoluo ~]# tail [-n number] 文件 
    参数:
    -n  :后面接数字,代表显示几行的意思
    范例:
    [root@xiaoluo ~]#tail /etc/man.config
    # 默认的情况中,显示最后的十行!若要显示最后的 20 行,就得要这样:
    
    [root@xiaoluo ~]# tail -n 20 /etc/man.config
    复制代码

    8.od (查看非文本文件)
    我们上面提到的一些命令,都是在查阅纯文本档 (ASCII 格式的档案) 的内容。 那么万一我们想要查阅非文本文件,举例来说,例如 /usr/bin/passwd 这个执行档的内容时, 又该如何去读出信息呢?事实上,由于执行档通常是 binary file ,使用上头提到的指令来读取他的内容时, 确实会产生类似乱码的数据!那怎么办?没关系,我们可以利用 od 这个命令来进行查看!

    复制代码
    [root@xiaoluo ~]# od [-t TYPE] 文件
    参数:
    -t  :后面可以接各种『类型 (TYPE)』的输出,例如:
          a       :利用默认的字符来输出;
          c       :使用 ASCII 字符来输出
          d[size] :利用十进制(decimal)来输出数据,每个整数占用 size bytes ;
          f[size] :利用浮点数(floating)来输出数据,每个数占用 size bytes ;
          o[size] :利用八进制(octal)来输出数据,每个整数占用 size bytes ;
          x[size] :利用十六进制(hexadecimal)来输出数据,每个整数占用 size bytes ;
    范例:
    [root@xiaoluo ~]#  od -t c /usr/bin/passwd
    0000000 177   E   L   F 001 001 001                  
    0000020 002   003   001       260 225 004     4      
    0000040 020   E               4          a     (  
    0000060 035   034   006         4         4 200 004  
    0000100   4 200 004   340       340       005      
    .....中间省略.......
    复制代码

    使用这个命令,我们就可以将数据文件或者二进制文件的内容读出来。

    本篇随笔主要记录了与Linux文件和目录管理相关的一些重要命令,由于时间关系,关于与Linux文件和目录管理相关的一些重要命令还没有记录完,其他常见的一些命令例如 touch 、以及涉及到文件与目录默认权限想过的umask命令将会在下一篇随笔中记录!!!!

  • 相关阅读:
    ES5-Array的新增方法
    ES5-Object扩展方法
    JS利用HTML5的Web Worker实现多线程
    git合并分支到master上面
    JS线程及回调函数执行
    JS实现继承
    蓝桥杯 高精度加法
    蓝桥杯 阶乘计算
    【题集】k倍区间(抽屉原理)
    代码填空:全排列
  • 原文地址:https://www.cnblogs.com/zb9222/p/5895598.html
Copyright © 2020-2023  润新知