Linux命令-文件管理篇-cat

ThreeWords

1.cat 说明

cat 是一个文本文件查看和连接工具。查看一个文件的内容,用cat比较简单,就是cat 后面直接接文件名。

2.使用权限

所有使用者
<!-- more -->

3.cat 语法

  • 语法格式
cat [-AbeEnstTuv] [--help] [--version] fileName
  • 参数说明
-n 或 --number:由 1 开始对所有输出的行数编号。
-b 或 --number-nonblank:和 -n 相似,只不过对于空白行不编号。
-s 或 --squeeze-blank:当遇到有连续两行以上的空白行,就代换为一行的空白行。
-v 或 --show-nonprinting:使用 ^ 和 M- 符号,除了 LFD 和 TAB 之外。
-E 或 --show-ends : 在每行结束处显示 $。
-T 或 --show-tabs: 将 TAB 字符显示为 ^I。
-A, --show-all:等价于 -vET。
-e:等价于"-vE"选项;
-t:等价于"-vT"选项;

4.cat 实例

  • 查看/etc/bashrc的内容
[root@elk1 ~]# cat /etc/bashrc    
  • 查看/etc/目录下的bashrc内容,并且对非空白行进行编号,行号从1开始
[root@elk1 ~]# cat -b /etc/bashrc  
...
    70        SHELL=/bin/bash
    71        # Only display echos from profile.d scripts if we are no login shell
    72        # and interactive - otherwise just process them to set envvars
    73        for i in /etc/profile.d/*.sh; do
    74            if [ -r "$i" ]; then
    75                if [ "$PS1" ]; then
    76                    . "$i"
    77                else
    78                    . "$i" >/dev/null
    79                fi
    80            fi
    81        done

    82        unset i
    83        unset -f pathmunge
    84    fi
    85    # vim:ts=4:sw=4
  • 对/etc目录中的profile的所有的行(包括空白行)进行编号输出显示
[root@elk1 ~]# cat -n /etc/bashrc
...
    65    
    66        # By default, we want umask to get set. This sets it for non-login shell.
    67        # Current threshold for system reserved uid/gids is 200
    68        # You could check uidgid reservation validity in
    69        # /usr/share/doc/setup-*/uidgid file
    70        if [ $UID -gt 199 ] && [ "`/usr/bin/id -gn`" = "`/usr/bin/id -un`" ]; then
    71           umask 002
    72        else
    73           umask 022
    74        fi
    75    
    76        SHELL=/bin/bash
    77        # Only display echos from profile.d scripts if we are no login shell
    78        # and interactive - otherwise just process them to set envvars
    79        for i in /etc/profile.d/*.sh; do
    80            if [ -r "$i" ]; then
    81                if [ "$PS1" ]; then
    82                    . "$i"
    83                else
    84                    . "$i" >/dev/null
    85                fi
    86            fi
    87        done
    88    
    89        unset i
    90        unset -f pathmunge
    91    fi
    92    # vim:ts=4:sw=4
  • 查看/etc/下的bashrc内容,并且在每行的结尾处附加$符号
[root@elk1 ~]# cat  -E /etc/bashrc
...
        esac$
    }$
$
    # By default, we want umask to get set. This sets it for non-login shell.$
    # Current threshold for system reserved uid/gids is 200$
    # You could check uidgid reservation validity in$
    # /usr/share/doc/setup-*/uidgid file$
    if [ $UID -gt 199 ] && [ "`/usr/bin/id -gn`" = "`/usr/bin/id -un`" ]; then$
       umask 002$
    else$
       umask 022$
    fi$
$
    SHELL=/bin/bash$
    # Only display echos from profile.d scripts if we are no login shell$
    # and interactive - otherwise just process them to set envvars$
    for i in /etc/profile.d/*.sh; do$
        if [ -r "$i" ]; then$
            if [ "$PS1" ]; then$
                . "$i"$
            else$
                . "$i" >/dev/null$
            fi$
        fi$
    done$
$
    unset i$
    unset -f pathmunge$
fi$
# vim:ts=4:sw=4$
  • cat 加参数-n 和nl工具差不多,文件内容输出的同时,都会在每行前面加上行号
[root@elk1 ~]# cat -n /etc/bashrc
[root@elk1 ~]# nl  /etc/bashrc
  • cat 可以同时显示多个文件的内容,比如我们可以在一个cat命令上同时显示两个文件的内容;
[root@elk1 ~]# cat /etc/fstab /etc/bashrc
  • cat 对于内容极大的文件来说,可以通过管道|传送到more 工具,然后一页一页的查看;

[root@elk1 ~]# cat /etc/fstab /etc/bashrc | more

5.cat 创建、连接文件功能

  • cat 有创建文件的功能,创建文件后,要以EOF或STOP结束;
[root@localhost ~]# cat >  ng-sec.txt  << EOF  
[root@elk1 ~]# cat >ng-sec.txt <<EOF
> hello
> this is cat test
> EOF
#说明:创建ng-sec.txt文件

[root@elk1 ~]# cat ng-sec.txt 
hello
this is cat test
  • 为刚刚创建的ng-sec.txt追加内容
[root@elk1 ~]# cat >>ng-sec.txt <<EOF
> This is new contents for test2
> EOF
[root@elk1 ~]# cat ng-sec.txt
hello
this is cat test
This is new contents for test2
# 说明:>>可以追加信息到文档,可以看到已经追加了一行信息
  • 通过cat 连接多个文件的内容并且输出到一个新文件中
假设我们有ng-sec01.txt、ng-sec02.txt,需要将他们文件内容合并后输出到ng-sec03.txt

注意:其原理是把两个文件的内容连接起来,然后创建ng-sec.txt文件,并且把几个文件的内容同时写入ng-sec03.txt中。特别注意的是,如果您输入到一个已经存在的ng-sec03.txt文件,会把该文件内容清空。

[root@localhost ~]# cat sir01.txt sir02.txt sir03.txt > sir04.txt
[root@elk1 ~]# cat ng-sec01.txt ng-sec02.txt > ng-sec03.txt
[root@elk1 ~]# cat ng-sec03.txt 
i am ng-sec01.txt
i am ng-sec02.txt
参考链接
runoob.com
aq1sw2的博客
阅读 1.5k

ng-sec
Focus Security and Good habit.

Focus Security and Good habit.

12 声望
0 粉丝
0 条评论

Focus Security and Good habit.

12 声望
0 粉丝
文章目录
宣传栏