Linux一行命令處理批量文件詳解
前言
最好的方法不一定是你最快能想到的。工作中針對臨時(shí)使用的腳本不要求健壯,寫出來越快越好。這里提供一種使用sed命令構(gòu)造命令解決處理批量文件的技巧,供參考。
需求案例1
將當(dāng)前目錄下所有的0_80_91.txt、0_80_92.txt、0_80_93.txt、。。。等幾十個(gè)文件的文件名修改為0_81_91.txt、0_81_92.txt、0_81_93.txt。也就是將文件名中的80修改為81。
實(shí)現(xiàn)命令為:ls *.txt |sed -nr 's/(0_)(80)(.*)/mv \1\2\3 \181\3/gp' | sh
#ls *.txt 0_80_91.txt 0_80_92.txt 0_80_93.txt #ls *.txt |sed -nr 's/(0_)(80)(.*)/mv \1\2\3 \181\3/gp' mv 0_80_91.txt 0_81_91.txt mv 0_80_92.txt 0_81_92.txt mv 0_80_93.txt 0_81_93.txt #ls *.txt |sed -nr 's/(0_)(80)(.*)/mv \1\2\3 \181\3/gp' | sh #ls *.txt 0_81_91.txt 0_81_92.txt 0_81_93.txt
需求案例2
將當(dāng)前目錄下的所有的0_80_91.Z、0_80_92.Z、0_80_93.Z文件通過命令cc_uncompress調(diào)用解壓并輸出到指定文件。調(diào)用格式為cc_uncompress -s 0_80_91.txt -d 1.txt。1.txt可以是任意文件名。
實(shí)現(xiàn)命令1為:ls *.Z | sed -nr 's/(.*)/cc_uncompress -s \1 -d \1.txt/gp'
#ls *.Z | sed -nr 's/(.*)/cc_uncompress -s \1 -d \1.txt/gp' cc_uncompress -s 0_80_91.Z -d 0_80_91.Z.txt cc_uncompress -s 0_80_92.Z -d 0_80_92.Z.txt cc_uncompress -s 0_80_93.Z -d 0_80_93.Z.txt #ls *.Z | sed -nr 's/(.*)/cc_uncompress -s \1 -d \1.txt/gp' | sh
實(shí)現(xiàn)命令2為:find . -name "*.Z" -exec cc_uncompress -s {} -d {}.bak \;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于Read-only file system問題的解決
這篇文章主要介紹了關(guān)于Read-only file system問題的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
CentOS下使用Squid架設(shè)CDN服務(wù)器的方法
這篇文章主要介紹了CentOS下使用Squid架設(shè)CDN服務(wù)器的方法,需要的朋友可以參考下2014-07-07
Linux之使用split將一個(gè)大文件拆分成多個(gè)小文件
這篇文章主要介紹了Linux之使用split將一個(gè)大文件拆分成多個(gè)小文件實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
apache服務(wù)出現(xiàn)Forbidden 403問題的解決方法總結(jié)
這篇文章主要介紹了apache服務(wù)出現(xiàn)Forbidden 403問題的解決方法總結(jié),需要的朋友可以參考下2014-08-08
使用Apache ab工具對Apache服務(wù)器進(jìn)行簡單的壓力測試
這篇文章主要介紹了使用Apache ab工具對Apache服務(wù)器進(jìn)行簡單的壓力測試的方法,文中還對如何查看當(dāng)前Apache的連接數(shù)的方法作了介紹,需要的朋友可以參考下2016-03-03

