zoukankan      html  css  js  c++  java
  • 《Unix&Linux大学教程》学习笔记四:标准I/O 与 过滤器

    1:标准IO

    Unix中的标准IO主要包括:标准输入、标准输出(正常输出)、标准错误(异常信息)

    2:重定向输出

    内容 > 文件名 :将内容输出到文件,并且覆盖文件原来内容;文件不存在则新建
    内容 >> 文件名:将内容追加到文件末尾

    3:重定向输入

    指令 < 文件名 :从文件中读取数据给指令处理

    4:管道线

    一个程序的标准输出能自动作为下一个程序的标准输入。

    指令1 | 指令2 :指令1的输出作为指令2的输入

    5:组合输出

    tee 文件名:从标准输入读取数据,并向标准输出和文件发送数据

    6:长选项与短选项

    短选项: -字符

    长选项:--单词

    7:过滤器——任何能从标准输入读取文本数据,经过处理后往标准输出写入文本的程序

    例如:sort程序

    8:如何组合使用过滤器

    熟练使用Unix是指:能够熟练运用Unix程序员们已经写好的众多程序来解决自己的问题。

    分解问题:针对自己遇到的问题,进行分解。

    选择程序:对每个小问题,使用适合的程序(过滤器)来处理。

    组合:然后使用 管道线 连接起来。

    9:最简单的过滤器——cat

    cat :接收标准输入,并将内容发送到标准输出
    cat > 文件:重定向输出到文件
    cat >> 文件:重定向追加输出到文件中
    cat 文件:从文件中读取数据
    cat file... :按顺序读取多个文件,并且将读取内容显示在屏幕上
    cat file... > 组合文件:按顺序读取多个文件,并且将读取内容写入到标准输出【可用于组合多个文件】
    cat file... | 指令:按顺序读取多个文件,并且将读取内容通过管道输送给指令程序

    10:常用过滤器

    11:分拆文件——split

    split -l lines file:将file文件分拆成每个文件最大行数为lines行的小文件

    12:文本反转——tac

    tac files... > 文件:从files文件们读取数据,将文本行顺序反转后写入到标准输出

    13:各行字符反转——rev

    rev 文件 :将文件中每行字符反转

    14:从文件头尾选择数据——在管道线中使用head、tail

    ...指令 | head -n lines :将输出的头n行提取
    ...指令 | tail -n lines :将输出的尾n行提取

    15:按列删除数据——colrm(column remove)

    colrm [startcol] [endcol]:删除开始~结束列【适用于二维、表格显示的数据】

    16:文件比较过滤器

    【查分与补丁:使用 diff 旧文件 新文件 得出差分,然后在其他地方使用 patch 按照差分来修改旧文件,就得到了新文件。这就是原始的 差分—补丁 思想。】

    17:逐字节比较——cmp

    cmp 文件1 文件2

    18:按行比较,有序

    comm 文件1 文件2

    19:无序比较、差分——diff

    diff 文件1 文件2

    20:按列抽取数据——cut

    cut -c list file:list为要抽取的列下标集合,如 1,2,3,4

     21:组合数据列——patse

    patse files...:将多个文件中内容按列组合,成为一张大表

    22:创建行号

    nl -v 起始行号 -i 行号增量 files... :为文件中每行创建行号

    23:统计行、单词和字符数量——wc(word count)

    wc files
    =======
    输出:行数 单词数 字符数 文件名

    24:制表符 替换成 空格

    expand files

    25:空格 替换成 制表符

    unexpand files

    26:拆分长行

    fold -w 行宽(小于等于80) file1 > file2

    【一行80字符:因为第一代计算机使用穿孔卡片存储数据,当时的卡片一行80列,每列一个字符】

    27:格式化段落

    fmt file

    28:按页格式化——pr

    pr file

    29:按特定模式(正则)选取行——grep

    grep pattern files :按特定模式抽取行

     30:选取特定模式开头的行——look

    look pattern files

    31:数据排序——sort

    sort [-d -f -n] infile > outfile:将infile数据排序后输出到outfile
    sort -c file:检查文件数据是否有序

    32:ASCII码字符顺序

    【常用记忆:空格在数字之前,数字在大写之前,大写在小写之前】

    33:重复行操作——uniq

    uniq  file:去除重复行后输出
    uniq -d file1 > file2:查看重复行
    uniq -c file1 > file2:统计重复行数
    uniq -u file:查看唯一重复行

    34:合并两个文件中的有序数据——join

    join [-1 field][-2 field] file1 file2:根据文件1与文件2中对应的field值相同的行合并在一起

    35:拓扑排序——tsort

    tsort file:对文件进行拓扑排序

    36:字符替换——tr

    tr 原字符 替换字符 < file 【注意是字符替换】
  • 相关阅读:
    php或JS中输出判断项
    拿大神的博客来记一下
    2017.6.8 项目进展
    2017.6.8
    2017.5.18
    2017.5.17
    2017.5.16
    如何实现从php传数据到js
    项目笔记
    tp框架之Model类与命名空间
  • 原文地址:https://www.cnblogs.com/ygj0930/p/8072913.html
Copyright © 2011-2022 走看看