• Linux学习笔记:linux命令之目录处理命令


    目录处理命令

    ls

    • 命令名称:ls
    • 英文原意:list
    • 执行权限:所有用户
    • 功能:显示目录文件
    • 语法:ls 选项[-ald] [文件或目录]
    • -a:显示所有文件,包括隐藏文件
    • -l:详细信息显示
    • -d:查看目录属性

    -a

    -a能显示所有文件,包括隐藏文件。隐藏文件以.开头。

    -l

     1atomy@atomy-virtual-machine:~/桌面$ ls -l /
    2总用量 1918440
    3lrwxrwxrwx   1 root root          7 5月   6 11:48 bin -> usr/bin
    4drwxr-xr-x   4 root root       4096 5月   6 12:00 boot
    5drwxrwxr-x   2 root root       4096 5月   6 11:50 cdrom
    6drwxr-xr-x  19 root root       4140 5月   9 09:17 dev
    7drwxr-xr-x 131 root root      12288 5月   9 09:04 etc
    8drwxr-xr-x   3 root root       4096 5月   6 11:51 home
    9lrwxrwxrwx   1 root root          7 5月   6 11:48 lib -> usr/lib
    10lrwxrwxrwx   1 root root          9 5月   6 11:48 lib32 -> usr/lib32
    11lrwxrwxrwx   1 root root          9 5月   6 11:48 lib64 -> usr/lib64
    12lrwxrwxrwx   1 root root         10 5月   6 11:48 libx32 -> usr/libx32
    13drwx------   2 root root      16384 5月   6 11:47 lost+found
    14drwxr-xr-x   3 root root       4096 5月   6 12:10 media
    15drwxr-xr-x   3 root root       4096 5月   6 12:16 mnt
    16drwxr-xr-x   2 root root       4096 2月  10 02:47 opt
    17dr-xr-xr-x 371 root root          0 5月   9 09:17 proc
    18drwx------   4 root root       4096 5月   9 09:16 root
    19drwxr-xr-x  33 root root        880 5月   9 09:17 run
    20lrwxrwxrwx   1 root root          8 5月   6 11:48 sbin -> usr/sbin
    21drwxr-xr-x   8 root root       4096 2月  10 02:57 snap
    22drwxr-xr-x   2 root root       4096 2月  10 02:47 srv
    23-rw-------   1 root root 1964400640 5月   6 11:48 swapfile
    24dr-xr-xr-x  13 root root          0 5月   9 09:17 sys
    25drwxrwxrwt  21 root root       4096 5月   9 09:18 tmp
    26drwxr-xr-x  14 root root       4096 2月  10 02:48 usr
    27drwxr-xr-x  14 root root       4096 2月  10 02:56 var

    这是使用-l查看根目录下文件的信息。第一行是总计(total),Total后面的数字是指当前目录下所有文件所占用的空间总和。可以使用ls –lh查看,也可使用ls –alh查看。

    我们以home文件的信息为例分析各个字段

    1drwxr-xr-x   3 root root       4096 5月   6 11:51 home

    第一部分:文件属性字段

    文件属性字段总共有10个字符组成

    第一个字符表示文件类型

    • -:二进制文件
    • d:目录
    • l:软链接文件

    之后每三个字符为一组,第一组表示u,即所有者;第二组表示g,即所属组;第三组表示o,即其他人

    他们的权限有三种表示:r、w、x

    • r:读
    • w:写
    • x:执行

    rwx表示这个文件可读可写可执行,r--表示这个文件只可以读,不可以写也不可以执行,-用来表示没有这个权限。

    因此drwxr-xr-x的含义就是表示这是一个目录,所有者(即root)拥有读、写、执行的权限,所属组拥有读和执行的权限,但没有写的权限,其他人拥有读和执行的权限,但没有写的权限。

    第二部分:目录/链接个数

    文件硬链接数或目录子目录数

    • 如果一个文件不是目录那么这一字段表示,这个文件所具有的硬链接数,即这个文件总共有多少个文件名.

    • 1-rw-r--r-- 1 root root 1581 11月 24 18:14 anaconda-ks.cfg
      2第2字段的值为1,说明这个文件只有anaconda-ks.cfg这一个文件名.即只有一个指向该链接的硬链接. 
    • 可以使用ls -i来查看文件的硬链接数。

    • 如果是一个目录,则第2字段表示该目录所含子目录的个数。

    第三部分:文件拥有者

    该字段表示这个文件是属于哪个用户的

    **第四部分:文件拥有者所在的组 **

    一个用户可以加入很多个组,但是其中有一个是主组,就是显示在第4字段的名称。

    第五部分:文件大小

    • 如果是文件,则表示该文件的大小,单位为字节。
    • 如果是目录,则表示该目录符所占的大小,并不表示该目录下所有文件的大小。请注意是文件夹本身的大小,而不是文件夹以及它下面的文件的总大小。

    如果想要看到具象的文件大小,可以用ls -lh,这样会附带上文件大小的单位。

    1atomy@atomy-virtual-machine:~/桌面$ ls -lh /home
    2总用量 4.0K
    3drwxr-xr-x 14 atomy atomy 4.05月   6 15:01 atomy

    第六部分:文件创建月份

    第七部分:文件创建日期

    第八部分:文件创建时间

    第九部分:文件名

    -d

    如果想看一个文件夹的信息,要加上-d,否则会显示这个文件夹下的文件信息

    1ls -ld /etc

    一般情况下,-d会和-l一起使用。

    mkdir

    • 命令名称:mkdir

    • 英文原意:make directories

    • 执行权限:所有用户

    • 功能描述:创建新目录

    • 语法

    • 1mkdir -p [目录名]
    • -p:递归创建

      • 递归创建就是一个目录本身不存在,就会先创建这个目录,如下:

      • 1mkdir /tmp/test/test01
        2
        3tmp下是没有test文件夹的,所以会提示创建失败要用如下方法:
        4
        5mkdir -p /tmp/test/test01
    • 同时创建多个目录(已经创建了test)

      • <br />mkdir /tmp/test/test01 /tmp/test/test02 /tmp/test/test03<br />

    pwd

    • 命令名称:pwd
    • 英文原意:print working directory
    • 执行权限:所有用户
    • 功能描述:显示当前目录
    • 语法:pwd

    cd

    • 命令名称:cd
    • 英文原意:change directory
    • 执行权限:所有用户
    • 功能描述:切换目录
    • 语法:cd [目录]

    特殊目录:

    • .:当前目录
    • ..:上一级目录
    • cd ..回到上级目录

    rmdir

    • 命令名称:rmdir
    • 英文原意:remove empty directories
    • 执行权限:所有用户
    • 功能描述:删除空目录
    • 删除的目录不是空目录会提示失败:目录非空
    • 语法:rmdir [目录名]

    cp

    • 命令名称:cp
    • 英文原意:copy
    • 执行权限:所有用户
    • 功能描述:复制文件或目录
    • 语法:cp -rp [源文件或目录] [目标目录]
    • -r:复制目录
    • -p:保留文件属性

    1.如果复制的是目录,就要加上-r,如

    1cp -r /tmp/test/test01 /root

    上面的语句就是将test01复制到root下

    2.可以同时复制多个文件

    1cp /etc/gai.conf /etc/gamemode.ini /tmp具体如下:root@atomy-virtual-machine:/etc# cp /etc/gai.conf /etc/gamemode.ini /tmproot@atomy-virtual-machine:/etc# cd /tmproot@atomy-virtual-machine:/tmp# ls_cafenv-appconfig_                                                                  systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-systemd-resolved.service-9AZqDhconfig-err-7lSB6k                                                                   systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-systemd-timesyncd.service-iI6Byigai.conf                                                                            systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-upower.service-Emh8lhgamemode.ini                                                                        tracker-extract-files.1000ssh-HsQTLczBrZ8o                                                                    tracker-extract-files.125systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-colord.service-Oxys1e              vmware-atomysystemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-ModemManager.service-1HeSRi        VMwareDnDsystemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-switcheroo-control.service-3ISK0i  vmware-rootsystemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-systemd-logind.service-3bdVEi      vmware-root_1153-4013330019这两个文件也新增在tmp中了。

    注意,复制过来的文件相当于创建了一个新文件,日期是变化的

    etc下的文件

    1-rw-r--r--  1 root root    2584 2月   1  2020 gai.conf-rw-r--r--  1 root root    4372 5月  18  2020 gamemode.ini

    tmp下的文件

    1-rw-r--r-- 1 root  root  2584 5月   9 15:47 gai.conf-rw-r--r-- 1 root  root  4372 5月   9 15:47 gamemode.ini

    3.使用-p来解决上面的问题

    保留原来文件的属性

    4.在复制的同时可以改名

    1cp -r /tmp/test/test02 /tmp/testcopy将test02复制到tmp下并改名为testcopy,具体如下:root@atomy-virtual-machine:/tmp# cp -r /tmp/test/test02 /tmp/testcopyroot@atomy-virtual-machine:/tmp# ls_cafenv-appconfig_                                                            systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-switcheroo-control.service-3ISK0i  tracker-extract-files.1000config-err-7lSB6k                                                             systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-systemd-logind.service-3bdVEi      tracker-extract-files.125gai.conf                                                                      systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-systemd-resolved.service-9AZqDh    vmware-atomygamemode.ini                                                                  systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-systemd-timesyncd.service-iI6Byi   VMwareDnDssh-HsQTLczBrZ8o                                                              systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-upower.service-Emh8lh              vmware-rootsystemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-colord.service-Oxys1e        test                                                                                vmware-root_1153-4013330019systemd-private-a77e8ee0988c4b05b0e3a30c7f6f5967-ModemManager.service-1HeSRi  testcopy

    mv

    • 命令名称:mv
    • 英文原意:move
    • 执行权限:所有用户
    • 功能描述:剪切(移动)文件、改名
    • 语法:mv [源文件或目录] [目标目录]
    1root@atomy-virtual-machine:/tmp# mv /tmp/test/test03 /tmp/testcopyroot@atomy-virtual-machine:/tmp# ls /tmp/testcopytest03

    可以和cp一样剪切的时候改名,也可以一次移动多个文件或目录

    因此,我们使用这个命令对文件或目录重命名

    1root@atomy-virtual-machine:/tmp# mv /tmp/testcopy/test03 /tmp/testcopy/test03renameroot@atomy-virtual-machine:/tmp# ls /tmp/testcopytest03rename

    rm

    • 命令名称:rm
    • 英文原意:remove
    • 执行权限:所有用户
    • 功能描述:删除文件
    • 语法:rm -rf [文件或目录]
    • -r:删除目录
    • -f:强制删除
  • 相关阅读:
    php责任链模式
    php工厂模式
    php观察者模式
    php单例模式
    php的抽象类
    Mysqli的常用函数
    PDO的基本操作
    算法--各种算法
    file_get_post实现post请求
    redis的5种数据结构的使用场景介绍
  • 原文地址:https://www.cnblogs.com/kylinxxx/p/14769994.html
Copyright © 2020-2023  润新知