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
相关推荐
Shanxun Liao21 分钟前
Cenots 7.9 配置多台 SSH 互信登陆免密码
linux·运维·ssh
j_xxx404_24 分钟前
Linux:第一个程序--进度条|区分回车与换行|行缓冲区|进度条代码两个版本|代码测试与优化
linux·运维·服务器
looking_for__1 小时前
【Linux】Ext系列文件系统
linux
最贪吃的虎2 小时前
Git: rebase vs merge
java·运维·git·后端·mysql
OliverH-yishuihan2 小时前
开发linux项目-在 Windows 上 基于“适用于 Linux 的 Windows 子系统(WSL)”
linux·c++·windows
残 风2 小时前
pg兼容mysql框架之语法解析层(openHalo开源项目解析)
数据库·mysql·开源
九皇叔叔3 小时前
MySQL 数据库 MVCC 机制
数据库·mysql
南棱笑笑生3 小时前
20251224给飞凌OK3588-C开发板适配Rockchip原厂的Buildroot【linux-6.1】系统时确认ssh服务【内置dropbear】
linux·c语言·ssh·rockchip
I · T · LUCKYBOOM3 小时前
30.Firewalld-Linux
linux·运维·安全
沙滩小绵羊3 小时前
Linux常见命令
linux·运维·服务器