zoukankan      html  css  js  c++  java
  • Shell—文件内容操作

    读取文件的每一行内容并输出

    #!/bin/bash
    
    # 方法1
    while read line
    do
        echo $line
    done < a.txt
    
    
    # 方法2
    cat a.txt | while read line
    do
        echo $line
    done
    
    # 方法3
    # for line in `cat  a.txt`
    for line in $(cat a.txt)
    do
        echo $line
    done
    

    文件内容排序工具 sort 和 uniq

    sort:sort是一个以行为单位对文件内容进行排序的工具,也可以根据不同的数据类型来排序。

    用法:sort [选项] 参数

    • -n:按照数字进行排序
    • -r:反向排序
    • -u:等同于uniq,表示相同的数据仅显示一行
    • -f:忽略大小写      -b:忽略每行前面的空格      -M:按照月份进行排序
    • -t:指定分隔符,默认使用Tab键分隔     -o <输出文件>:将排序后的结果转存至指定文件   -k:指定排序区域
    [root@localhost ~]# sort /etc/passwd
    [root@localhost ~]# sort -r /etc/passwd
    

    uniq:去除重复行,并统计每行出现的次数(相邻行)。uniq工具通常与sort命令结合使用,用于报告或者忽略文件中的重复行。

    用法:uniq [选项] 参数

    • -c:进行计数
    • -d:仅显示重复行(这里的重复行,仅限相邻行重复。如果有两行重复但是不相邻,则不满足)
    • -u:仅显示出现一次的行
    [root@localhost ~]# uniq -c test.txt
    [root@localhost ~]# uniq -u test.txt
    [root@localhost ~]# sort -n test.txt | uniq -c  # 删除test.txt文件中重复行,并统计该行重复次数
    
    [root@localhost ~]# sort -n test.txt | awk '{if($0!=line)print; line=$0}'
    [root@localhost ~]# sort -n test.txt | sed '$!N; /^(.*)
    1$/!P; D'
    

    统计文件的行数、字数、字节数, 并将统计结果显示输出

    [root@localhost ~]# wc -l /etc/passwd         # 统计文件的行数(里面内容的行数)
    [root@localhost ~]# wc -c /etc/passwd         # 统计文件的字节数
    [root@localhost ~]# wc -m /etc/passwd         # 统计文件的字符数
    [root@localhost ~]# wc -w /etc/passwd         # 统计单词出现次数
    [root@localhost ~]# wc - lcw file1 file2 
    [root@localhost ~]# ls -l | wc -l             # 用来统计当前目录下的文件数
    

      

  • 相关阅读:
    单片机学习01__跑起你的流水灯
    python2与python3共存
    rpi-kali 搭建网络靶场
    P3388 【模板】割点(割顶)
    P3387 【模板】缩点
    P1069 细胞分裂
    The Unique MST[不严格的次小生成树]
    P3369 【模板】普通平衡树
    Netty的线程模型可不是Reactor这么简单
    SpringBoot+Mybatis+MySQL实现读写分离
  • 原文地址:https://www.cnblogs.com/liuhaidon/p/11843632.html
Copyright © 2011-2022 走看看