Linux文件管理系统

本文介绍了Linux系统中查看和管理文件内容的方法,包括使用cut、more/less、head/tail、grep、uniq和sort等命令。详细讲解了各命令的使用格式、常见选项以及在实际操作中的应用示例,如查看文件内容、去除重复行、按特定字段排序等,旨在帮助用户高效地处理文本数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.文件内容浏览

cut查看文件内容:

命令格式:cat [选项] 文件名列表
说明:文件名可使用通配符
常用选项:
-n——对输出内容中的所有行标注行号。
-b——对输出内容中的非空行标注行号。
cut查看/etc/passwd文件内容,且输出时带行号
cat -n passwd在这里插入图片描述

more/less查看文件内容

命令格式: more | less [选项] 文件名
常用选项:
-数字——仅适用于more命令,用来指定分页显示时每页的行数。
+num——指定从文件的第num行开始显示。
-c——从顶部清屏然后显示文件内容
-N——仅适用于less命令,其作用是在每行前添加输出行号。

交互操作方法:

按Enter键向下逐行滚动
按空格键向下翻一屏、按b键向上翻一屏
文件末尾时more会自动退出,less 按q键退出

使用more/less查看/etc/passwd内容,且每页显示10行

more -10 passwd

在这里插入图片描述

head/tail查看文件内容

命令格式:head | tail [选项] 文件名
常用选项有:
-num——指定需要显示文件多少行的内容,若不指定,默认只显示十行。
-f——使tail不停地去读取和显示文件最新的内容, 以监视文件内容的变化。这样有实时监视的效果。
tail命令更多的用于查看系统日志文件,以便于观察重要的系统消息,特别是结合使用-f选项,tail会自动实时
地把打开文件中的新消息显示到屏幕上,从而跟踪日志文件末尾的内容变化,直至按【Ctrl+C】键终止显示
和跟踪
使用head/tail分别查看文件前5行内容和后5行内容

head -5 passwd

在这里插入图片描述

tail -5 passwd

在这里插入图片描述

grep查看文件内容

grep命令用于按行提取文本内容
语法格式为:grep [参数] 文件名称
-b 将可执行文件(binary)当作文本文件(text)来搜索
-c 仅显示找到的行数
-i 忽略大小写
-n 显示行号
-v 反向选择——仅列出没有“关键词”的行。

使用grep查看/etc/passwd中和root相关的内容

grep root passed

在这里插入图片描述

2. cut命令的使用

命令格式:cut [选项参数] filename
选项与参数:

-d:分隔符,按照指定分隔符分割列。与 -f 一起使用

-f:依据 -d 的分隔字符将一段信息分割成为数段,用 -f 取出第几段的意思(列号,提取第几列)

-c:以字符 (characters) 的单位取出固定字符区间

-b:以字节为单位进行分割

使用默认定界符切割文件内容,且输出且切割后的第一个字段
cut -d ' ' -f 1 cut_data.txt

在这里插入图片描述

切割文件内容,且输出切割后的第一个字段和第三个字段
cut -d ' ' -f 1,3 cut_data.txt

在这里插入图片描述

按字节切割:输出切割的第一个字节到第十个字节的内容
cut -b 1-10 cut_data.txt

在这里插入图片描述
按字符切割:输出切割后的第一个字符和第5个字符的内容

cut -c 1,5 cut_data.txt

在这里插入图片描述

3.uniq命令的使用

命令格式:uniq [OPTION]... [INPUT [OUTPUT]]
选项:
-c, --count 打印每行出现的次数

-d, --repeated 只打印重复出现的行

-D 打印所有重复行

–all-repeated[=METHOD] 类似 -D,使用空行分隔每个组,METHOD=none,prepend,separate

-f, --skip-fields=N 不比较前 N 个字段

–group[=METHOD] 使用空行分隔每个组METHOD=separate,prepend,append,both

-i, --ignore-case 忽略大小写

-s, --skip-chars=N 不比较前 N 个字符

-u, --unique 只打印出现一次的行

-z, --zero-terminated 行分隔符是 NUL 而不是换行符

-w, --check-chars=N 比较不多于 N 个字符

–help 帮助文档

–version 版本信息

使用uniq输出去重后的结果
uniq uniq_data.txt

在这里插入图片描述

使用uniq只输出重复的行
uniq -d uniq_data.txt

在这里插入图片描述

使用uniq输出不重复的行
uniq -u uniq_data.txt

在这里插入图片描述

使用uniq显示重复次数
uniq -c uniq_data.txt

在这里插入图片描述

4.sort命令的使用

命令格式:sort [option] [file(s) ]
-b 忽略每行前面开始出的空格字符。
-c 检查文件是否已排好序,如果乱序,则输出第一个乱序的行的相关信息,最后返回1
-C 检查文件是否已排好序,如果乱序,不输出内容,仅返回1
-d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
-f 排序时,将小写字母视为大写字母。
-i 排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
-m 将几个排序好的文件进行合并。
-M 将前面3个字母依照月份的缩写进行排序。
-n 依照数值的大小排序。
-u 意味着是唯一的(unique),输出的结果是去完重了的。
-o <输出文件> 将排序后的结果存入指定的文件。
-r 以相反的顺序来排序。
-t <分隔字符> 指定排序时所用的栏位分隔字符。

对num.txt进行排序,且将结果输出到sorted_num.txt中
sort -n num.txt > sorted_num.txt

在这里插入图片描述

对args.txt进行排序,且将结果输出到sorted_args.txt中
sort args.txt > sorted_args.txt

在这里插入图片描述

对num.txt和args.txt进行排序,且将结果输出到sorted_merge.txt中
sort num.txt args.txt > sorted_merge.txt

在这里插入图片描述

合并sorted_args.txt和sorted_num.txt且输出
cat sorted_args sorted_num

在这里插入图片描述

给定文件info_txt:按第二列作为key进行排序
[root@server ~]#more info_txt
No Name Score
1  zhang  20
2  li      80
3  wang   90
4  sun    60
sort -t ' ' -k 2 info_txt

在这里插入图片描述

5.

将26个小写字母的后13位换成大写字母
cat ABCfile |tr n-z N-Z
#ABCfile文件内容位26个小写字母

在这里插入图片描述

将hello 123 word 456中的数字替换成空字符
cat aafile |tr 0-9 ' '
#aafile文件内容为hello 123 word 456

在这里插入图片描述

将hello 123 word 456中字母和空格替换掉,只保留数字
cat aafile |tr -d a-z,A-Z,‘ ’

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值