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; /^\(.*\)\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             # 用来统计当前目录下的文件数

  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值