linux | sort、uniq、history、xargs、grep 正则表达式(不深入)

1.正则表达式

sort命令

bash 复制代码
sort  aaa.txt

#把内容读到内存,然后以行为单位进行排序并把结果输出到stdout(因为直接把排序结果输出,所以可以重定向),但是并不修改源文件内容。

参考如下

bash 复制代码
sort hello > hello_sort

uniq命令

bash 复制代码
uniq  aaa.txt

#流程和sort类似,也是把相邻的相同行去掉,最后输出。注意间隔的相同行无法去除。

如何把文件所有向同行都给去掉,达到完全去重?

xargs

bash 复制代码
history		#查看历史命令		参考 上键 下键

参考:find /usr/include -name stdio.h | xargs ls -l

解决方式如下

bash 复制代码
sort aaa.txt | uniq > bbb.txt		#严格去重后的数据保存在bbb.txt中
bash 复制代码
wc [-c/-l/-w] aaa.txt		#-c计算文件多少字节、-l计算多少行、-w计算多少个字
bash 复制代码
#iconv 修改字符集
#iconv [options] [-f from-encoding] [-t to-encoding] [inputfile]
iconv -f gbk -t utf-8 aaa.txt			#例如把aaa.txt的gbk编码格式转换成utf-8
bash 复制代码
grep #(全局 正则表达式 打印)	

参数:

-E 表示使用正则表达式regexp

-n 显示行号

-i 忽略正则表达式中的大小写

正则表达式:

基本单位:普通字符,转义字符, [0-9]

基本操作:

连接 ab

重复

重复零次或一次 ?

重复一次或多次 +

重复任意次数 *

{x, y}匹配前一项内容重复的次数介于x和y之间

{x} 匹配前一项内容x次

{x,} 匹配前一项最少x次

{, x} 匹配前一项最多x次

举例:

bash 复制代码
grep -nE "txt" a.txt			#匹配所有包含txt的行
bash 复制代码
grep -nE "[rw]" a.txt	#匹配含r或者含w
bash 复制代码
grep -nE "(rw)" #a.txt匹配包含rw
相关推荐
Bert.Cai13 分钟前
Linux expr命令详解
linux·运维·服务器
噢,我明白了2 小时前
表单的完整 CRUD 练习【极简个人记账本】(含前端后端链接mySQL)
java·前端·数据库·mysql
2501_9219392610 小时前
MHA高可用
数据库·mysql
彩色的黑'''10 小时前
[root@localhost ~]#,Linux系统的命令提示符为啥现在变成-bash-4.2#了,哪里设置的
linux·运维·bash
_Evan_Yao11 小时前
MySQL 基础:SELECT、WHERE、JOIN 的第一次使用
数据库·mysql
源远流长jerry11 小时前
Linux 网络发送机制深度解析:从应用到网线
linux·服务器·网络·网络协议·tcp/ip
南境十里·墨染春水11 小时前
linux学习进展 shell编程
linux·运维·学习
goyeer12 小时前
【ITIL4】32服务实践 - 问题管理(Problem Management)
linux·运维·服务器·企业数字化·it管理·itil·it治理
怀旧,12 小时前
【Linux网络编程】8. 网络层协议 IP
linux·网络·tcp/ip
RH23121112 小时前
2026.5.12 Linux
java·linux·数据结构