色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

行處理工具

馬哥Linux運維 ? 來源:馬哥Linux運維 ? 2025-01-03 09:32 ? 次閱讀

行處理工具

grep:用于查找文件里符合條件的字符串或正則表達式。

grep 指令用于查找內(nèi)容包含指定的范本樣式的文件,如果發(fā)現(xiàn)某文件的內(nèi)容符合所指定的范本樣式,預設 grep 指令會把含有范本樣式的那一列顯示出來。若不指定任何文件名稱,或是所給予的文件名為-,則 grep 指令會從標準輸入設備讀取數(shù)據(jù)。

-i:忽略大小寫進行匹配。

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

-n:顯示匹配行的行號。

-r:遞歸查找子目錄中的文件。

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

-c:只打印匹配的行數(shù)。

-A : 打印搜索結果后幾行的數(shù)據(jù)

-B : 打印搜索結果前幾行的數(shù)據(jù)

-C : 打印搜索結果前后幾行的數(shù)據(jù)

 grep --color=auto passwd  #高亮顯示過濾內(nèi)容
 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$' #尋找不區(qū)分大小寫以bash結尾的行,同時打印行號
 cat passwd | grep -niv 'bash$' #反選不區(qū)分大小寫以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,可以獲取某列的數(shù)值,或可以獲取每行從某個字符到某個字符的全部字符。

-c :以字符為單位進行分割。

-d :自定義分隔符,默認為制表符。

-f :與-d一起使用,指定顯示哪個區(qū)域。

[root@ecs-shell ~]#  cat passwd   #源文件內(nèi)容
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 命令用于將文本文件內(nèi)容加以排序。

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

-n 依照數(shù)值的大小排序。

-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  #查看以":"分割的,第三列從小向大排序的內(nèi)容
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  #查看以":"分割的,第三列從大向小排序的內(nèi)容
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  #去掉重復出現(xiàn)的行

111
222
aaa
dsdsa
sda
vvv

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

uniq:uniq 命令用于檢查及刪除文本文件中重復出現(xiàn)的行列,一般與 sort 命令結合使用。

-c或--count 在每列旁邊顯示該行重復出現(xiàn)的次數(shù)。

-d或--repeated 僅顯示重復出現(xiàn)的行列。

-u或--unique 僅顯示出一次的行列。

[輸入文件] 指定已排序好的文本文件。如果不指定此項,則從標準讀取數(shù)據(jù);

[輸出文件] 指定輸出的文件。如果不指定此選項,則將內(nèi)容顯示到標準輸出設備(顯示終端)。

[root@ecs-shell ~]# cat 3.txt #查看源文件
aaa
111
222
111
222
222
sda
dsdsa
vvv
[root@ecs-shell ~]#  cat 3.txt | uniq #對源文件中連續(xù)重復的行去重
aaa
111
222
111
222
sda
dsdsa
vvv
[root@ecs-shell ~]# cat 3.txt | uniq -c #對重復的行計數(shù)
      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 #打印出其中連續(xù)重復的行
222

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

tee: tee命令用于讀取標準輸入的數(shù)據(jù),并將其內(nèi)容輸出成文件。

tee指令會從標準輸入設備讀取數(shù)據(jù),將其內(nèi)容輸出到標準輸出設備,同時保存成文件。

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

[root@ecs-shell ~]# echo "helloworld" | tee abc.txt  #標準覆蓋輸?shù)轿覀兊奈募推聊簧?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 #拿到的是一個操作信息,可以使第一個文件變?yōu)榈诙€文件。
3c3 #3c3是指第一個文件第三行通過改變可以變成第二個文件第三行
< write_enable=YES #第一個文件第三行
---
> write_enable=NO #第二個文件第三行
8,9c8 #8,9c8是指第一個文件通過改變第八,九行可以變成第八行
< ooooooo
< xferlog_std_format=YES
---
> xferlog_std_format=NO
10a10 #10a10指第十行增加第二個文件第十行的內(nèi)容
> aaa #第二個文件第十行內(nèi)容
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 ****  #第一個文件的行數(shù)
  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 ---- #第二個文件的行數(shù)
  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變?yōu)槲募?[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 指令從標準輸入設備讀取數(shù)據(jù),經(jīng)過字符串轉譯后,將結果輸出到標準輸出設備。

-c, --complement:反選設定字符。也就是符合 SET1 的部份不做處理,不符合的剩余部份才進行轉換

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

-s, --squeeze-repeats:縮減連續(xù)重復的字符成指定的單個字符

-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
#要實現(xiàn)如上的效果,也可以這樣寫
[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

#將數(shù)字換為“@”
[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
#刪除所有字母和數(shù)字
[root@ecs-shell ~]#  cat passwd | tr -d "A-Za-z1-9" 
:0::/://
:::::/://
:::::/://
::::://://
:::::///://
:::/://
:::/://
:::/://
:::::///://
:::/://
::://://
:: ://://
:::::/://
-::::  :/://
::::  :/://
::::  :/://
:::::///://
::::- :///://
:::::///://
:::::/://
::::          ://://


#縮減連續(xù)重復的字符
[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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 文件
    +關注

    關注

    1

    文章

    570

    瀏覽量

    24803
  • 工具
    +關注

    關注

    4

    文章

    314

    瀏覽量

    27873

原文標題:行處理工具

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Flexus X 實例安裝 ShowDoc 文檔管理工具

    ShowDoc 文檔管理工具,開啟高效協(xié)作之旅。 一、Flexus 云服務器 X 實例介紹 1.1 Flexus 云服務器 X 實例簡介 華為云 Flexus 云服務器 X 實例官網(wǎng):Flexus云服務器X實例
    的頭像 發(fā)表于 01-13 15:51 ?117次閱讀
    Flexus X 實例安裝 ShowDoc 文檔管<b class='flag-5'>理工具</b>

    詳解14種常用產(chǎn)品表面處理工

    設計元素的一種方法。?我們常用的產(chǎn)品表面處理工藝有:?IMD、OMD、噴涂、?PVD、電鍍、NCVM?、印刷?、鐳雕、咬花、?PPVD退鍍、?電泳?、?蝕刻、?噴砂?、?軋光等。?表面處理的目的是為了
    的頭像 發(fā)表于 12-30 10:01 ?774次閱讀

    ADI電源管理工具推薦

    ADI 提供了一整套電源管理工具,幫助您一次性正確設計電源解決方案。ADI 的電源管理工具支持從零件推薦到性能估算、實用的電源樹設計、電路仿真和系統(tǒng)級優(yōu)化的整個設計過程。探索這些免費且強大的工具
    的頭像 發(fā)表于 12-23 09:46 ?387次閱讀

    cmp項目管理工具的優(yōu)缺點

    CMP項目管理工具,在不同的語境下有不同的含義。一種是指綜合項目管理平臺(Comprehensive Management Platform),它旨在整合和優(yōu)化項目的各個方面,包括時間管理、資源管理
    的頭像 發(fā)表于 12-17 09:42 ?258次閱讀

    cmp與其他數(shù)據(jù)處理工具的比較

    CMP在不同的語境下有不同的含義,一種是指芯片多處理器(Chip Multiprocessors),另一種是指“比較”(compare)的縮寫。 CMP與編程語言中的比較功能 CMP(比較操作
    的頭像 發(fā)表于 12-17 09:30 ?207次閱讀

    Simulink與 MATLAB 的結合使用 Simulink中的信號處理方法

    在工程和科學研究中,信號處理是一個重要的領域,涉及到信號的采集、分析、處理和生成。MATLAB 提供了豐富的信號處理工具箱,而 Simulink 提供了一個直觀的圖形界面,使得復雜的信號處理
    的頭像 發(fā)表于 12-12 09:25 ?458次閱讀

    鍍鎳處理工藝步驟 鍍鎳與鍍鉻的區(qū)別

    鍍鎳處理工藝步驟 鍍鎳是一種表面處理技術,用于提高金屬零件的耐腐蝕性、耐磨性和裝飾性。以下是鍍鎳的基本工藝步驟: 前處理 : 除油 :使用化學或電解除油劑去除金屬表面的油脂。 除銹 :使用酸洗液去除
    的頭像 發(fā)表于 12-10 14:43 ?880次閱讀

    揭秘PCB板的八種神秘表面處理工

    印制電路板(PCB)作為電子元器件的支撐和電子元器件電路連接的提供者,在電子設備中占據(jù)重要地位。而PCB的表面處理工藝,對于保證電路板的性能、提高焊接質量以及增強電路板的耐腐蝕性都至關重要。本文將詳細介紹PCB板子的八種表面處理工藝,以幫助讀者更好地了解和選擇適合自身需求
    的頭像 發(fā)表于 11-08 13:02 ?993次閱讀
    揭秘PCB板的八種神秘表面<b class='flag-5'>處理工</b>藝

    數(shù)字化工具在工作中的應用

    Teams和Zoom,它們促進了團隊成員之間的即時溝通和協(xié)作。 文檔處理工具:如Microsoft Office 365、Google Workspace和Notion,這些工具使得文檔創(chuàng)建、編輯
    的頭像 發(fā)表于 10-27 17:27 ?1128次閱讀

    哪些PCB表面處理工藝適合量產(chǎn)呢

    哪些PCB表面處理工藝適合量產(chǎn)呢
    的頭像 發(fā)表于 09-30 15:52 ?387次閱讀

    美國佐治亞理工學院一蒞臨達實智能調研

    近日,美國佐治亞理工學院“聚焦數(shù)據(jù)科學領域·深度探訪粵港澳大灣區(qū)”學生代表團來深交流。美國佐治亞理工學院(Georgia Institute of Technology)一探訪了大灣區(qū)科技企業(yè)代表達實智能。
    的頭像 發(fā)表于 09-26 09:21 ?532次閱讀

    HDI線路板盤中孔處理工

    HDI線路板的盤中孔處理工藝是為了應對電子元件集成度提高和元器件封裝縮小帶來的挑戰(zhàn)。在復雜的HDI電路板設計中,由于管腳間距較小,有時需要在焊盤上打孔(即盤中孔)以便于信號和電源從下一層線路板傳遞
    的頭像 發(fā)表于 09-25 16:52 ?639次閱讀
    HDI線路板盤中孔<b class='flag-5'>處理工</b>藝

    PCB板的表面處理工藝及其優(yōu)缺點和適用場景

    一站式PCBA智造廠家今天為大家講講pcb板各種表面處理工藝的適用場景有哪些?PCB板各種表面處理工藝的適用場景。PCB的表面處理工藝對于電路板的性能、可靠性和耐用性都有很大影響。 以下是一些常見
    的頭像 發(fā)表于 07-04 09:38 ?565次閱讀

    紀科技宣布推出數(shù)字實現(xiàn)一站式優(yōu)化修復工具AmazeECO

    2024年5月16日,芯紀科技有限公司(以下簡稱“芯紀”)宣布推出數(shù)字實現(xiàn)一站式優(yōu)化修復工具AmazeECO。
    的頭像 發(fā)表于 05-16 14:25 ?483次閱讀

    微軟棄用WMIC,Windows管理工具的變革

    近期,微軟再次出手對Windows 11內(nèi)置的WMIC管理工具實施了禁止,并聲明未來的Windows 11最新版(預計將于今年晚些時候推出的24H2版本)將不再支持該應用。
    的頭像 發(fā)表于 01-29 10:18 ?1651次閱讀
    主站蜘蛛池模板: 6 10young俄罗斯 | 国产精品高清在线观看93 | 日韩在线视频www色 日韩在线看片中文字幕不卡 | 亚洲成人国产 | 亚洲欧美视频在线 | 99re热有精品国产 | 久久精品国产午夜伦班片 | 日日做夜夜欢狠狠免费软件 | 俄罗斯6一12呦女精品 | 国产亚洲精品V在线观看一 国产亚洲精品a在线观看app | 黑粗硬大欧美在线视频 | 99久久精品国产自免费 | 伊人久久青草青青综合 | 国产GV天堂亚洲国产GV刚刚碰 | 亚洲欧洲自拍偷拍 | 国内精品偷拍在线观看 | 韩剧19禁啪啪无遮挡大尺度 | 午夜特级毛片 | 国产日韩精品一区二区在线观看 | 美女伊人网 | 女人张开腿让男人桶爽免 | 国产91网站在线观看免费 | 熟妇内谢69XXXXXA片 | 最新无码专区在线视频 | 美女动态图真人后进式 | 国色精品VA在线观看免费视频 | 一色狗影院 | 欧美亚洲日韩国产在线在线 | 好色的妹妹 | 超碰视频97av | 久久精品国产午夜伦班片 | 99re久久免费热在线视频手机 | 芳草地在线观看免费观看 | 久久久久久久久a免费 | 99国产在线观看 | 国产亚洲精品网站在线视频 | 2022国产91精品久久久久久 | 国产精品无码无卡毛片不卡视 | 1区2区3区4区产品不卡码网站 | 成人性生交大片免费看金瓶七仙女 | 果冻传媒完整免费网站在线观看 |