0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

行处理工具

马哥Linux运维 来源:马哥Linux运维 2025-01-03 09:32 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

行处理工具

grep:用于查找文件里符合条件的字符串或正则表达式。

grep 指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设 grep 指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为-,则 grep 指令会从标准输入设备读取数据。

-i:忽略大小写进行匹配。

-v:反向查找,只打印不匹配的行。

-n:显示匹配行的行号。

-r:递归查找子目录中的文件。

-l:只打印匹配的文件名。

-c:只打印匹配的行数。

-A : 打印搜索结果后几行的数据

-B : 打印搜索结果前几行的数据

-C : 打印搜索结果前后几行的数据

 grep --color=auto passwd  #高亮显示过滤内容
 alias grep='grep --color=auto'   #别名 
 alias grep='grep --color=auto' >> /etc/bashrc  #写入配置文件,使其一直生效
 source /etc/bashrc  #读取配置文件
 grep 'a*' passwd  
 vim passwd 
 cat passwd | grep  'bash$' #寻找以bash结尾的行
 cat passwd | grep -ni 'bash$' #寻找不区分大小写以bash结尾的行,同时打印行号
 cat passwd | grep -niv 'bash$' #反选不区分大小写以bash结尾的行,同时打印行号
 grep -nB 2 'ftp' passwd   #打印以ftp过滤的行及其前两行,同时打印行号
 grep -nB 2 '^ftp' passwd  #打印以ftp开头过滤的行及其前两行,同时打印行号
 grep -nA 2 '^ftp' passwd  #打印以ftp过滤的行及其前两行,同时打印行号
 grep -nB5 2 '^ftp' passwd  #打印以ftp过滤的行及其前两行,同时打印行号
 grep -A 2 '^ftp' passwd   #打印以ftp过滤的行及其后两行
 grep -C 2 '^ftp' passwd   ##打印以ftp过滤的行及其前后两行
 grep -o  '^ftp' passwd   #只打印ftp关键字

cut:类似于awk,可以获取某列的数值,或可以获取每行从某个字符到某个字符的全部字符。

-c :以字符为单位进行分割。

-d :自定义分隔符,默认为制表符。

-f :与-d一起使用,指定显示哪个区域。

[root@ecs-shell ~]#  cat passwd   #源文件内容
root0root:/root:/bin/bash
bin1bin:/bin:/sbin/nologin
daemon2daemon:/sbin:/sbin/nologin
adm3adm:/var/adm:/sbin/nologin
lp4lp:/var/spool/lpd:/sbin/nologin
sync5sync:/sbin:/bin/sync
shutdown6shutdown:/sbin:/sbin/shutdown
halt7halt:/sbin:/sbin/halt
mail8mail:/var/spool/mail:/sbin/nologin
operator11operator:/ROOT:/sbin/nologin
games12games:/usr/games:/sbin/nologin
ftp14FTP User:/var/ftp:/sbin/nologin
nobody99Nobody:/:/sbin/nologin
systemd-network192systemd Network Management:/:/sbin/nologin
dbus81System message bus:/:/sbin/nologin
polkitd999User for polkitd:/:/sbin/nologin
postfix89:/var/spool/postfix:/sbin/nologin
sshd74Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
chrony998:/var/lib/chrony:/sbin/nologin
tcpdump72:/:/sbin/nologin
tss59Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin

[root@ecs-shell ~]#  cat passwd | cut -d":" -f1   #获取第一列全部的username
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
games
ftp
nobody
systemd-network
dbus
polkitd
postfix
sshd
chrony
tcpdump
tss


[root@ecs-shell ~]#  cat passwd | awk -F":" '{print $1}'  #awk也可以做到
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
games
ftp
nobody
systemd-network
dbus
polkitd
postfix
sshd
chrony
tcpdump
tss

[root@ecs-shell ~]#  cat passwd | cut -d":" -f1,7   #打印第一列和第七列
root:/bin/bash
bin:/sbin/nologin
daemon:/sbin/nologin
adm:/sbin/nologin
lp:/sbin/nologin
sync:/bin/sync
shutdown:/sbin/shutdown
halt:/sbin/halt
mail:/sbin/nologin
operator:/sbin/nologin
games:/sbin/nologin
ftp:/sbin/nologin
nobody:/sbin/nologin
systemd-network:/sbin/nologin
dbus:/sbin/nologin
polkitd:/sbin/nologin
postfix:/sbin/nologin
sshd:/sbin/nologin
chrony:/sbin/nologin
tcpdump:/sbin/nologin
tss:/sbin/nologin

[root@ecs-shell ~]# cat passwd | awk -F":" '{print $1,$NF}' #awk打印第一列和第七列
root /bin/bash
bin /sbin/nologin
daemon /sbin/nologin
adm /sbin/nologin
lp /sbin/nologin
sync /bin/sync
shutdown /sbin/shutdown
halt /sbin/halt
mail /sbin/nologin
operator /sbin/nologin
games /sbin/nologin
ftp /sbin/nologin
nobody /sbin/nologin
systemd-network /sbin/nologin
dbus /sbin/nologin
polkitd /sbin/nologin
postfix /sbin/nologin
sshd /sbin/nologin
chrony /sbin/nologin
tcpdump /sbin/nologin
tss /sbin/nologin

[root@ecs-shell ~]#  cat passwd | cut -c 1-5  #获取每行的第1-5个字符
root:
bin:x
daemo
adm:x
lp
sync:
shutd
halt:
mail:
opera
games
ftp:x
nobod
syste
dbus:
polki
postf
sshd:
chron
tcpdu
tss:x

[root@ecs-shell ~]#  cat passwd | cut -c 10-  #获取每行的第10个字符到每行结束
0/root:/bin/bash
/bin:/sbin/nologin
2daemon:/sbin:/sbin/nologin
/var/adm:/sbin/nologin
lp:/var/spool/lpd:/sbin/nologin
0/sbin:/bin/sync
x0/sbin:/sbin/shutdown
0/sbin:/sbin/halt
12/var/spool/mail:/sbin/nologin
x0/ROOT:/sbin/nologin
2games:/usr/games:/sbin/nologin
50:FTP User:/var/ftp:/sbin/nologin
99Nobody:/:/sbin/nologin
etwork192systemd Network Management:/:/sbin/nologin
System message bus:/:/sbin/nologin
998:User for polkitd:/:/sbin/nologin
89::/var/spool/postfix:/sbin/nologin
Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
998:/var/lib/chrony:/sbin/nologin
72::/:/sbin/nologin
59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin

#相关命令:
 cat passwd | awk -F":" '{print $1}'
 cat passwd | cut -d":" -f1,7
 cat passwd | awk -F":" '{print $1,$NF}'
 cat passwd | cut -c 1-5
 cat passwd | cut -c 10-

sort: sort 命令用于将文本文件内容加以排序。

-b 忽略每行前面开始出的空格字符。

-n 依照数值的大小排序。

-u 意味着是唯一的(unique),输出的结果是去完重了的。

-o<输出文件> 将排序后的结果存入指定的文件。

-r 以相反的顺序来排序。

[root@ecs-shell ~]# cat passwd
root0root:/root:/bin/bash
bin1bin:/bin:/sbin/nologin
daemon2daemon:/sbin:/sbin/nologin
adm3adm:/var/adm:/sbin/nologin
lp4lp:/var/spool/lpd:/sbin/nologin
sync5sync:/sbin:/bin/sync
shutdown6shutdown:/sbin:/sbin/shutdown
halt7halt:/sbin:/sbin/halt
mail8mail:/var/spool/mail:/sbin/nologin
operator11operator:/ROOT:/sbin/nologin
games12games:/usr/games:/sbin/nologin
ftp14FTP User:/var/ftp:/sbin/nologin
nobody99Nobody:/:/sbin/nologin
systemd-network192systemd Network Management:/:/sbin/nologin
dbus81System message bus:/:/sbin/nologin
polkitd999User for polkitd:/:/sbin/nologin
postfix89:/var/spool/postfix:/sbin/nologin
sshd74Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
chrony998:/var/lib/chrony:/sbin/nologin
tcpdump72:/:/sbin/nologin
tss59Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin

[root@ecs-shell ~]# cat passwd | sort -n -t":" -k3  #查看以":"分割的,第三列从小向大排序的内容
root0root:/root:/bin/bash
bin1bin:/bin:/sbin/nologin
daemon2daemon:/sbin:/sbin/nologin
adm3adm:/var/adm:/sbin/nologin
lp4lp:/var/spool/lpd:/sbin/nologin
sync5sync:/sbin:/bin/sync
shutdown6shutdown:/sbin:/sbin/shutdown
halt7halt:/sbin:/sbin/halt
mail8mail:/var/spool/mail:/sbin/nologin
operator11operator:/ROOT:/sbin/nologin
games12games:/usr/games:/sbin/nologin
ftp14FTP User:/var/ftp:/sbin/nologin
tss59Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
tcpdump72:/:/sbin/nologin
sshd74Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
dbus81System message bus:/:/sbin/nologin
postfix89:/var/spool/postfix:/sbin/nologin
nobody99Nobody:/:/sbin/nologin
systemd-network192systemd Network Management:/:/sbin/nologin
chrony998:/var/lib/chrony:/sbin/nologin
polkitd999User for polkitd:/:/sbin/nologin

[root@ecs-shell ~]# cat passwd | sort -nr -t":" -k3  #查看以":"分割的,第三列从大向小排序的内容
polkitd999User for polkitd:/:/sbin/nologin
chrony998:/var/lib/chrony:/sbin/nologin
systemd-network192systemd Network Management:/:/sbin/nologin
nobody99Nobody:/:/sbin/nologin
postfix89:/var/spool/postfix:/sbin/nologin
dbus81System message bus:/:/sbin/nologin
sshd74Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
tcpdump72:/:/sbin/nologin
tss59Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
ftp14FTP User:/var/ftp:/sbin/nologin
games12games:/usr/games:/sbin/nologin
operator11operator:/ROOT:/sbin/nologin
mail8mail:/var/spool/mail:/sbin/nologin
halt7halt:/sbin:/sbin/halt
shutdown6shutdown:/sbin:/sbin/shutdown
sync5sync:/sbin:/bin/sync
lp4lp:/var/spool/lpd:/sbin/nologin
adm3adm:/var/adm:/sbin/nologin
daemon2daemon:/sbin:/sbin/nologin
bin1bin:/bin:/sbin/nologin
root0root:/root:/bin/bash


[root@ecs-shell ~]# cat 3.txt 
aaa
111
222
111
222
222
sda
dsdsa
vvv

[root@ecs-shell ~]# cat 3.txt | sort -u  #去掉重复出现的行

111
222
aaa
dsdsa
sda
vvv

#相关命令
 cat passwd 
 cat passwd | sort -n -t":" -k3 
 cat passwd | sort -nr -t":" -k3

uniq:uniq 命令用于检查及删除文本文件中重复出现的行列,一般与 sort 命令结合使用。

-c或--count 在每列旁边显示该行重复出现的次数。

-d或--repeated 仅显示重复出现的行列。

-u或--unique 仅显示出一次的行列。

[输入文件] 指定已排序好的文本文件。如果不指定此项,则从标准读取数据;

[输出文件] 指定输出的文件。如果不指定此选项,则将内容显示到标准输出设备(显示终端)。

[root@ecs-shell ~]# cat 3.txt #查看源文件
aaa
111
222
111
222
222
sda
dsdsa
vvv
[root@ecs-shell ~]#  cat 3.txt | uniq #对源文件中连续重复的行去重
aaa
111
222
111
222
sda
dsdsa
vvv
[root@ecs-shell ~]# cat 3.txt | uniq -c #对重复的行计数
      1 aaa
      1 111
      1 222
      1 111
      2 222
      1 sda
      1 dsdsa
      1 vvv
      1 
[root@ecs-shell ~]#  cat 3.txt | uniq -d #打印出其中连续重复的行
222

#相关命令
 cat 3.txt | uniq
 cat 3.txt | uniq -c
 cat 3.txt | uniq -d

tee: tee命令用于读取标准输入的数据,并将其内容输出成文件。

tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。

-a或--append 附加到既有文件的后面,而非覆盖它.

[root@ecs-shell ~]# echo "helloworld" | tee abc.txt  #标准覆盖输到我们的文件和屏幕上
helloworld
[root@ecs-shell ~]# echo "helloworld" | tee -a abc.txt  #标准追加输出到我们的文件和屏幕上
helloworld
[root@ecs-shell ~]# cat abc.txt 
helloworld
helloworld
[root@ecs-shell ~]# cat vsftpd.conf | grep -v "^#" | grep -v "^$" | tee 4.txt 
anonymous_enable=YES
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=YES
listen=NO
listen_ipv6=YES
pam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES
 
 echo "helloworld" | tee 1.txt
 cat 1.txt 
 echo "abc" | tee 1.txt
 cat 1.txt 
 cat vsftpd.conf | grep -v "^#" | grep -v "^$" | tee 4.txt

diff:Linux diff 命令用于比较文件的差异。

diff 以逐行的方式,比较文本文件的异同处。如果指定要比较目录,则 diff 会比较目录中相同文件名的文件,但不会比较其中子目录。

-c 上下文模式

-u 合并模式

[root@ecs-shell ~]# diff 1.txt  2.txt #拿到的是一个操作信息,可以使第一个文件变为第二个文件。
3c3 #3c3是指第一个文件第三行通过改变可以变成第二个文件第三行
< write_enable=YES #第一个文件第三行
---
> write_enable=NO #第二个文件第三行
8,9c8 #8,9c8是指第一个文件通过改变第八,九行可以变成第八行
< ooooooo
< xferlog_std_format=YES
---
> xferlog_std_format=NO
10a10 #10a10指第十行增加第二个文件第十行的内容
> aaa #第二个文件第十行内容
12c12,13  #同上
< pam_service_name=vsftpd
---
> bb
> ccpam_service_name=vsftpd

[root@ecs-shell ~]# cat 1.txt 
anonymous_enable=YES
local_enable=YES
local_umask=022
cccca
dirmessage_enable=YES
connect_from_port_20=YES
xferlog_std_format=NO
listen=NO
oooooooop
listen_ipv6=YES
ccpam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES
[root@ecs-shell ~]# cat 2.txt  
anonymous_enable=YES
local_enable=YES
write_enable=NO
local_umask=022
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=NO
listen=NO
aaa
listen_ipv6=YES
bb
ccpam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES

#对两个文件进行一定修改后,使用-c模式来比较
[root@ecs-shell ~]# diff -c 1.txt 2.txt 
*** 1.txt       2023-12-06 1046.672339322 +0800   #修改时间
--- 2.txt       2023-12-04 2227.956996693 +0800   #修改时间
***************
*** 1,13 ****  #第一个文件的行数
  anonymous_enable=YES
  local_enable=YES
  local_umask=022
- cccca    #第一个文件删除此行
  dirmessage_enable=YES
  connect_from_port_20=YES
  xferlog_std_format=NO
  listen=NO
! oooooooop  #将此行改为“ aaa ”
  listen_ipv6=YES
  ccpam_service_name=vsftpd
  userlist_enable=YES
  tcp_wrappers=YES
--- 1,15 ---- #第二个文件的行数
  anonymous_enable=YES
  local_enable=YES
+ write_enable=NO   #第一个文件加上此行
  local_umask=022
  dirmessage_enable=YES
+ xferlog_enable=YES
  connect_from_port_20=YES
  xferlog_std_format=NO
  listen=NO
! aaa 
  listen_ipv6=YES
+ bb        #第一个文件加上此行
  ccpam_service_name=vsftpd
  userlist_enable=YES
  tcp_wrappers=YES
  #使用-u来比较
 [root@ecs-shell ~]# diff -u 1.txt 2.txt  
--- 1.txt       2023-12-06 1046.672339322 +0800
+++ 2.txt       2023-12-04 2227.956996693 +0800
@@ -1,13 +1,15 @@
 anonymous_enable=YES
 local_enable=YES
+write_enable=NO   #加上此行
 local_umask=022
-cccca   #删除此行
 dirmessage_enable=YES
+xferlog_enable=YES   #加上此行
 connect_from_port_20=YES
 xferlog_std_format=NO
 listen=NO
-oooooooop   #删除此行
+aaa  #加此行
 listen_ipv6=YES
+bb   #加此行
 ccpam_service_name=vsftpd
 userlist_enable=YES
 tcp_wrappers=YES 
  
#我们也可以基于diff对两个文件夹进行比较:
[root@ecs-shell ~]# ll test1
total 0
-rw-r--r-- 1 root root 0 Dec  6 11:05 file1
-rw-r--r-- 1 root root 0 Dec  6 11:05 file2
-rw-r--r-- 1 root root 0 Dec  6 11:05 file3
-rw-r--r-- 1 root root 0 Dec  6 11:05 file4
-rw-r--r-- 1 root root 0 Dec  6 11:05 file5
[root@ecs-shell ~]# ll test2
total 0
-rw-r--r-- 1 root root 0 Dec  6 11:05 file1
-rw-r--r-- 1 root root 0 Dec  6 11:05 file2
-rw-r--r-- 1 root root 0 Dec  6 11:05 file3
-rw-r--r-- 1 root root 0 Dec  6 11:05 test1
-rw-r--r-- 1 root root 0 Dec  6 11:05 test2
-rw-r--r-- 1 root root 0 Dec  6 11:05 test3

[root@ecs-shell ~]# diff test1 test2
Only in test1: file4
Only in test1: file5
Only in test2: test1
Only in test2: test2
Only in test2: test3
 
#diff还可以搭配patch补丁工具使用:可以直接使文件1变为文件二
[root@ecs-shell ~]# diff 1.txt 2.txt > file.patch
[root@ecs-shell ~]# patch 1.txt file.patch 
patching file 1.txt
[root@ecs-shell ~]# diff 1.txt 2.txt
[root@ecs-shell ~]# cat 1.txt 
anonymous_enable=YES
local_enable=YES
write_enable=NO
local_umask=022
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=NO
listen=NO
aaa
listen_ipv6=YES
bb
ccpam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES
[root@ecs-shell ~]# cat 2.txt 
anonymous_enable=YES
local_enable=YES
write_enable=NO
local_umask=022
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=NO
listen=NO
aaa
listen_ipv6=YES
bb
ccpam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES

paste:paste 命令用于合并文件的列

paste 指令会把每个文件以列对列的方式,一列列地加以合并。

-d<间隔字符>或--delimiters=<间隔字符> 用指定的间隔字符取代跳格字符。

-s或--serial 串列进行而非平行处理。

--help 在线帮助。

--version 显示帮助信息。

[文件…] 指定操作的文件路径

 [root@ecs-shell ~]# cat 4.txt 
anonymous_enable=YES
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=YES
listen=NO
listen_ipv6=YES
pam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES
[root@ecs-shell ~]# paste 3.txt 4.txt 
aaa     anonymous_enable=YES
111     local_enable=YES
222     write_enable=YES
111     local_umask=022
222     dirmessage_enable=YES
222     xferlog_enable=YES
sda     connect_from_port_20=YES
dsdsa   xferlog_std_format=YES
vvv     listen=NO
        listen_ipv6=YES
        pam_service_name=vsftpd
        userlist_enable=YES
        tcp_wrappers=YES
 #-s选项 把每个文件当一行输出
[root@ecs-shell ~]# paste -s 3.txt 4.txt 
aaa     111     222     111     222     222     sda     dsdsa   vvv
anonymous_enable=YES    local_enable=YES        write_enable=YES        local_umask=022 dirmessage_enable=YES   xferlog_enable=YES      connect_from_port_20=YES        xferlog_std_format=YES  listen=NO       listen_ipv6=YES pam_service_name=vsftpd userlist_enable=YES     tcp_wrappers=YES 
#-d选项可以定义之间的分隔符
#定义|为分隔符
 [root@ecs-shell ~]# paste -d"|" 3.txt 4.txt  
aaa|anonymous_enable=YES
111|local_enable=YES
222|write_enable=YES
111|local_umask=022
222|dirmessage_enable=YES
222|xferlog_enable=YES
sda|connect_from_port_20=YES
dsdsa|xferlog_std_format=YES
vvv|listen=NO
|listen_ipv6=YES
|pam_service_name=vsftpd
|userlist_enable=YES
|tcp_wrappers=YES

#定义":"为分隔符
[root@ecs-shell ~]# paste -d":" 3.txt 4.txt  
aaa:anonymous_enable=YES
111:local_enable=YES
222:write_enable=YES
111:local_umask=022
222:dirmessage_enable=YES
222:xferlog_enable=YES
sda:connect_from_port_20=YES
dsdsa:xferlog_std_format=YES
vvv:listen=NO
:listen_ipv6=YES
:pam_service_name=vsftpd
:userlist_enable=YES
:tcp_wrappers=YES
  

tr: tr 命令用于转换或删除文件中的字符。

tr 指令从标准输入设备读取数据,经过字符串转译后,将结果输出到标准输出设备。

-c, --complement:反选设定字符。也就是符合 SET1 的部份不做处理,不符合的剩余部份才进行转换

-d, --delete:删除指令字符

-s, --squeeze-repeats:缩减连续重复的字符成指定的单个字符

-t, --truncate-set1:削减 SET1 指定范围,使之与 SET2 设定长度相等

--help:显示程序用法信息

--version:显示程序本身的版本信息

 
 [root@ecs-shell ~]# cat 1.txt 
anonymous_enable=YES
local_enable=YES
write_enable=NO
local_umask=022
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_20=YES
xferlog_std_format=NO
listen=NO
aaa
listen_ipv6=YES
bb
ccpam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES
 
 #使用NO去替换YES
 [root@ecs-shell ~]# cat 1.txt | tr "YES" "NO"
anonymous_enable=NOO
local_enable=NOO
write_enable=NO
local_umask=022
dirmessage_enable=NOO
xferlog_enable=NOO
connect_from_port_20=NOO
xferlog_std_format=NO
listen=NO
aaa
listen_ipv6=NOO
bb
ccpam_service_name=vsftpd
userlist_enable=NOO
tcp_wrappers=NOO
#使用“NO ”去替换yes
[root@ecs-shell ~]# cat 1.txt | tr "YES" "NO "
anonymous_enable=NO 
local_enable=NO 
write_enable=NO
local_umask=022
dirmessage_enable=NO 
xferlog_enable=NO 
connect_from_port_20=NO 
xferlog_std_format=NO
listen=NO
aaa
listen_ipv6=NO 
bb
ccpam_service_name=vsftpd
userlist_enable=NO 
tcp_wrappers=NO 
 #将所有小写字母换成大写
[root@ecs-shell ~]# cat 1.txt | tr "[a-z]" "[A-Z]" 
ANONYMOUS_ENABLE=YES
LOCAL_ENABLE=YES
WRITE_ENABLE=NO
LOCAL_UMASK=022
DIRMESSAGE_ENABLE=YES
XFERLOG_ENABLE=YES
CONNECT_FROM_PORT_20=YES
XFERLOG_STD_FORMAT=NO
LISTEN=NO
AAA
LISTEN_IPV6=YES
BB
CCPAM_SERVICE_NAME=VSFTPD
USERLIST_ENABLE=YES
TCP_WRAPPERS=YES
#要实现如上的效果,也可以这样写
[root@ecs-shell ~]#  tr "[a-z]" "[A-Z]"< 1.txt 
ANONYMOUS_ENABLE=YES
LOCAL_ENABLE=YES
WRITE_ENABLE=NO
LOCAL_UMASK=022
DIRMESSAGE_ENABLE=YES
XFERLOG_ENABLE=YES
CONNECT_FROM_PORT_20=YES
XFERLOG_STD_FORMAT=NO
LISTEN=NO
AAA
LISTEN_IPV6=YES
BB
CCPAM_SERVICE_NAME=VSFTPD
USERLIST_ENABLE=YES
TCP_WRAPPERS=YES

#将数字换为“@”
[root@ecs-shell ~]#  tr '0-9' '@' <1.txt 
anonymous_enable=YES
local_enable=YES
write_enable=NO
local_umask=@@@
dirmessage_enable=YES
xferlog_enable=YES
connect_from_port_@@=YES
xferlog_std_format=NO
listen=NO
aaa
listen_ipv@=YES
bb
ccpam_service_name=vsftpd
userlist_enable=YES
tcp_wrappers=YES

tr -d 是直接删除掉匹配到的字符

#删除所有小写字母
[root@ecs-shell ~]#  cat passwd | tr -d "a-z" 
:0::/://
:1::/://
:2::/://
:4:://://
:7::///://
:0::/://
:0::/://
:0::/://
:12::///://
:0::/ROOT://
:100:://://
:50:FTP U://://
:99/://
-:192: N M:/://
:81:S  :/://
:998:U  :/://
:89::///://
:74:P- SSH:///://
:996::///://
:72::/://
:59:A          ://://
#删除所有大写字母
[root@ecs-shell ~]#  cat passwd | tr -d "A-Z" 
root0root:/root:/bin/bash
bin1bin:/bin:/sbin/nologin
daemon2daemon:/sbin:/sbin/nologin
adm3adm:/var/adm:/sbin/nologin
lp4lp:/var/spool/lpd:/sbin/nologin
sync5sync:/sbin:/bin/sync
shutdown6shutdown:/sbin:/sbin/shutdown
halt7halt:/sbin:/sbin/halt
mail8mail:/var/spool/mail:/sbin/nologin
operator11operator:/:/sbin/nologin
games12games:/usr/games:/sbin/nologin
ftp14 ser:/var/ftp:/sbin/nologin
nobody99obody:/:/sbin/nologin
systemd-network192systemd etwork anagement:/:/sbin/nologin
dbus81ystem message bus:/:/sbin/nologin
polkitd999ser for polkitd:/:/sbin/nologin
postfix89:/var/spool/postfix:/sbin/nologin
sshd74rivilege-separated :/var/empty/sshd:/sbin/nologin
chrony998:/var/lib/chrony:/sbin/nologin
tcpdump72:/:/sbin/nologin
tss59ccount used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
#删除所有字母和数字
[root@ecs-shell ~]#  cat passwd | tr -d "A-Za-z1-9" 
:0::/://
:::::/://
:::::/://
::::://://
:::::///://
:::/://
:::/://
:::/://
:::::///://
:::/://
::://://
:: ://://
:::::/://
-::::  :/://
::::  :/://
::::  :/://
:::::///://
::::- :///://
:::::///://
:::::/://
::::          ://://


#缩减连续重复的字符
[root@ecs-shell ~]#  tr -s "a-z" < passwd
rot0rot:/rot:/bin/bash
bin1bin:/bin:/sbin/nologin
daemon2daemon:/sbin:/sbin/nologin
adm3adm:/var/adm:/sbin/nologin
lp4lp:/var/spol/lpd:/sbin/nologin
sync5sync:/sbin:/bin/sync
shutdown6shutdown:/sbin:/sbin/shutdown
halt7halt:/sbin:/sbin/halt
mail8mail:/var/spol/mail:/sbin/nologin
operator11operator:/ROOT:/sbin/nologin
games12games:/usr/games:/sbin/nologin
ftp14FTP User:/var/ftp:/sbin/nologin
nobody99Nobody:/:/sbin/nologin
systemd-network192systemd Network Management:/:/sbin/nologin
dbus81System mesage bus:/:/sbin/nologin
polkitd999User for polkitd:/:/sbin/nologin
postfix89:/var/spol/postfix:/sbin/nologin
shd74Privilege-separated SSH:/var/empty/shd:/sbin/nologin
chrony998:/var/lib/chrony:/sbin/nologin
tcpdump72:/:/sbin/nologin
ts59Acount used by the trousers package to sandbox the tcsd daemon:/dev/nul:/sbin/nologin


 ifconfig 
 mkdir test
 touch file
 touch file{0..9}
 touch file1{0-4}
 touch file1{0-4}.jpg
 ll
 cp file* test/
 ll test/
 ls
 rm file*
 rm -r file*
 yy
 y
 cd test/
 ls
 rm file1{0-4}
 rm file1{0-4}.jpg
 ls
 touch file1{0..4}.jpg
 ls file[123]
 ls file[123].jpg
 ls file[0-9]
 ls file*
 ls file[1-19]
 touch file-
 ls file[1-19]
 ls file[2-19]
 ls file[2-29]
 ls -l file[!0-9]
 ls -l file[!0-2]
 ls -l file[!0-3]
 ls -l file[!0-4]
 ls -l file[!0-5]
 ls -l file[!0-6]
 ll file{1,2,3,-,14}
 ll file{1,2,3,-,13}
 ll
 ll file{1..13}.jpg
 ll file{1..13}.*
 ll file{1..13}*
  date +%F
 echo "$date"
 echo "$(date)"
 echo "$(date +%F)"
 echo "$(date +%Y:%m:%d)"
 echo `$(date +%Y)`
 echo `$date +%Y`
 echo `$date +%F`
 echo `date +%F`
 echo "$(date +%F)"
 cat /etc/shell
 cat /etc/shells
 ll /bin/bash
 ll /bin/sh
 /bin/dash
 /bin/sh
 ls
 cd ..
 mkdir shell
 cd shell/
 vim 1.sh
 sh 1.sh 
 vim 1.sh 
 bash -x 1.sh 
 bash -n 1.sh 
 source 1.sh 
 ll
 man rename
 cd 
 ls
 cd test/
 ls
 rename file1{1..4}.jpg test{1..4}.jpg
 ls
 rename file1{1..4}.jpg test{1..4}.jpg file1*.jpg
 ls
 rename file1 test1 file1?.jpg
 ls
 history 
 /bin/bsh
 /bin/bash
 ps 
 echo $A
 env
 ps
 /bin/bsh
 /bin/bash
 ls
 ps
 cd ../shell/
 A=hello
 echo $A
 export $A
 export A
 env | grep A
 ls
 history 
" '{print $NF}'

链接:https://www.cnblogs.com/rallina/p/17930965.html

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 文件
    +关注

    关注

    1

    文章

    599

    浏览量

    26180
  • 工具
    +关注

    关注

    4

    文章

    320

    浏览量

    28955

原文标题:行处理工具

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    东软智与大连理工大学共建智能网联汽车技术联合创新中心

    5月23日,由东软智与大连理工大学共同发起建立的“智能网联汽车技术联合创新中心”在大连理工大学校园内落成。双方举办揭牌仪式,标志着这一产学研协同创新平台正式启航,将为中国智能网联汽车产业迈向高质量发展注入新动能。
    的头像 发表于 05-26 17:12 732次阅读

    英德斯联合维森影像推出工业专用CT图像处理工作站

    英德斯(YDSTECH)联合维森影像,推出一款工业专用CT图像处理工作站,专为CT三维重建、海量断层数据分割与处理场景打造,兼顾算力密度与工业级稳定性。
    的头像 发表于 04-29 11:13 541次阅读

    Ansible与SaltStack配置管理工具的对比

    在大规模服务器运维场景中,配置管理工具是基础设施自动化的核心组件。经过多年生产环境实践,Ansible和SaltStack作为两款主流的配置管理工具,各自占据了相当的市场份额。本文基于笔者在多个
    的头像 发表于 02-04 11:01 1001次阅读

    Linux Shell文本处理神器合集:15个工具+实战例子,效率直接翻倍

    在 Linux 系统中,文本是数据交互的 “通用语言”—— 日志文件、配置文件、数据报表、程序输出几乎都以文本形式存在。手动编辑文本不仅繁琐,还容易出错,而掌握 Shell 文本处理工具,能让你用几行命令完成批量筛选、数据提取、统计分析,甚至复杂的文本清洗。
    的头像 发表于 02-03 15:42 3350次阅读
    Linux Shell文本<b class='flag-5'>处理</b>神器合集:15个<b class='flag-5'>工具</b>+实战例子,效率直接翻倍

    长春理工大学领导一莅临联合光电参观交流

    12月26日,长春理工大学党委副书记周庆才、就业创业指导中心主任贾彦彬等一莅临联合光电参观交流。联合光电创始人谢晋国、人事总监甘露热情接待并全程陪同,双方围绕深化产教融合、拓宽人才输送渠道展开深入探讨。
    的头像 发表于 12-31 17:42 4377次阅读

    芯科技GloryEX入选国产EDA工具口碑榜

    来自一位资深用户反馈:“GloryEX在全芯片RC提取方面表现出色,处理大规模设计时速度快、精度高,对复杂互连结构的寄生参数捕捉准确。工具在后端Sign-off流程中能快速定位时序瓶颈,显著提升
    的头像 发表于 12-19 12:52 827次阅读

    中汽中心赴武汉理工大学走访交流

    2025年11月6日,中汽中心党委副书记王晓杉一赴武汉理工大学走访交流,与武汉理工大学党委常委、副校长胡剑就进一步深化校企合作进行交流座谈。
    的头像 发表于 11-12 17:54 1485次阅读

    上海理工大学师生一走进简仪科技总部

    10月15日,上海理工大学师生一走进简仪科技 (JYTEK) 总部,参加“医学人工智能实践教育基地”揭牌仪式暨首场AI实训活动。本次活动由上海理工大学健康与工程学院主办,简仪科技承办,标志着校企双方在人工智能与智能测控教育融合
    的头像 发表于 10-18 11:27 1550次阅读

    理工雷科亮相第22届信号处理学术年会

    2025年9月19日,第二十二届信号处理学术年会在北京会议中心隆重启幕。第二十二届信号处理学术年会是由中国电子学会信号处理分会和北京理工大学联合主办,致力于为国内信号
    的头像 发表于 09-23 12:53 1101次阅读

    江苏拓能半导体科技有限公司发布高速半导体信号处理工具平台,驱动芯片设计效率革命

    引言:国产工具突破,解锁高速信号处理新维度 2025年8月27日,江苏拓能半导体科技有限公司(以下简称“江苏拓能”)自主研发的 “高速半导体信号处理工具平台(V1.0)” 正式获得软件著作权(登记号
    的头像 发表于 09-02 15:17 851次阅读
    江苏拓能半导体科技有限公司发布高速半导体信号<b class='flag-5'>处理工具</b>平台,驱动芯片设计效率革命

    技术培训 | 南理工专场:同星汽车电子基础工具链暨TSMaster软件应用培训圆满落幕

    2025.8.20南理工TSMaster技术培训8月19日至20日,同星智能(TSMaster)线下技术培训专场再次走进南京理工大学,为来自车辆工程,智能底盘,机械工程等相关专业的60余位硕士、博士
    的头像 发表于 08-22 20:05 1417次阅读
    技术培训 | 南<b class='flag-5'>理工</b>专场:同星汽车电子基础<b class='flag-5'>工具</b>链暨TSMaster软件应用培训圆满落幕

    锂电池制造 | 电芯预处理工艺的步骤详解

    电芯预处理是锂电池包制造的首要工序,无论是新能源汽车的续航稳定性,还是储能系统的循环寿命,其根基都可追溯至预处理工序对电芯一致性的把控,其核心在于通过系统检测与筛选消除量产电芯的性能差异,为后续组装
    的头像 发表于 08-11 14:53 2237次阅读
    锂电池制造 | 电芯预<b class='flag-5'>处理工</b>艺的步骤详解

    上海理工大学一莅临简仪科技参观交流

    为推进校企合作,进一步促进人才培养与企业需求的精准对接,近日,上海理工大学副校长蔡永莲率队走访上海简仪科技有限公司(以下简称“简仪科技”),规划处、光电信息与计算机工程学院、能源与动力工程
    的头像 发表于 07-24 17:52 1064次阅读

    PCB表面处理工艺详解

    在PCB(印刷电路板)制造过程中,铜箔因长期暴露在空气中极易氧化,这会严重影响PCB的可焊性与电性能。因此,表面处理工艺在PCB生产中扮演着至关重要的角色。下面将详细介绍几种常见的PCB表面处理工
    的头像 发表于 07-09 15:09 1811次阅读
    PCB表面<b class='flag-5'>处理工</b>艺详解

    Splashtop 入选 Gartner 端点管理工具市场指南代表供应商

    近日,国际权威IT研究与咨询机构Gartner发布《端点管理工具市场指南》(MarketGuideforEndpointManagementTools)报告(以下简称“报告”),为企业评估技术供应商
    的头像 发表于 06-12 17:36 1371次阅读
    Splashtop 入选 Gartner 端点管<b class='flag-5'>理工具</b>市场指南代表供应商