❶ linux 如何將隱藏文件名前面的點去掉 我有大量的數據文件都是以點開頭的隱藏文件如:「.dataxxxx」
單純對目前目錄下的普通隱藏文件(就是當前目錄下的.*)進行處理,命令如下:
ls -adl .*|grep "^-"|awk '{print $NF}'|sed 's/^.//g'|xargs -i mv {.,}{}
❷ linux批量修改文件後綴名Linux下批量修改文件名的方法
linux批量修改文件後綴名,Linux下批量修改文件名的方法很多人還不知道,現在讓我們一起來看看吧!
Linux下批量修改文件名的方法
在Linux環境下修改文件名可以有不同的命令方式,比如rename、mv都可以進行修改,如果用戶正在了解這方面的知識,可以閱讀下文了解Linux修改文件名以及批量修改文件名的方法。
對於單個的文件,可以直接使用命令,那如果有大量的類似格式的文件名需要修改成其他格式的,該如何呢?
比如某次測試後,保存的文件為 Lan1.txt,Lan2.txt,……Lan100.txt
這一百個文件需要在前面添加前綴變成類似 ch7_Lan1.txt,如果你還想使用mv來一個一個多痛苦啊。
當前文件夾下,文件修改有四種方式:
1、使用while Loop加${//}來實現Lan到ch7_Lan的替換。
01find . -name "Lan*txt" -type f | read files02do03new=04mv05done復制代碼
find . -name "Lan*txt" -type f | read filesdonew=mvdone
2、充分利用awk的分隔符功能來實現:
01ls *Lan* | awk 'BEGIN{FS="Lan";OFS="ch7_Lan"}{printf "mv "$0" ";$1=$1;print $0}' | sh復制代碼
ls *Lan* | awk 'BEGIN{FS="Lan";OFS="ch7_Lan"}{printf "mv "$0" ";$1=$1;print $0}' | sh
首先,修改FS和OFS,輸入和輸出的分隔符。
其次,使用awk中的命令,拼接「mv Lan1.txt ch7_Lan1.txt」這條命令。
最後,使用|sh來執行一個shell命令來完成mv動作。
其中,$1=$1是必須的,這個是完成Lan===> ch7_Lan的關鍵(其實是可以使用$2=$2等來替換,只要一個賦值動作而已)
奇怪的是,難道沒有賦值動作,分隔符的改變就不能檢測出來么?
3、使用awk的內置命令,gsub和system來實現替換和命令執行。
01ls "*Lan*" | awk '{org=$0;gsub("Lan", "ch7_Lan");system("mv "org" "$1)}'復制代碼
ls "*Lan*" | awk '{org=$0;gsub("Lan", "ch7_Lan");system("mv "org" "$1)}'
首先保存原始的數據。
其次修改 Lan為 ch_Lan
最後執行mv動作
其中,最後system命令"mv "org""需要使用""來標記。
而且org也需要"",並且不能使用$org
1、對於awk命令中的變數,不需要用$來引用。
2、在system()中,變數需要使用""來標識,否則就被當成字元串來處理。
3、如果對變數進行$來進行引用,就會出現兩種情況:
3.1、正常情況下,可以被當成位置參數來引用。比如 NF表示當前行的記錄個數。比如echo "a b c d" | awk '{print NF, $NF}',這個會列印兩個變數,第一個是NF本身,其值為4;第二個是第四個位置參數,也就是$4,也就是d
3.2、非正常情況下:
3.2.1、如果變數本身就是個字元串。比如echo "a b c d" | awk '{va=「varA「;print va, $va}',因為後一個參數$va,由於va是個字元串,因此$va列印的就是$0
3.2.2、如果變數本身就是個數字,但是該值大於NF。 比如echo "a b c d" | awk '{va="varA";vb=6;print va, $va, vb, $vb, 1}',因為$vb相當於是$6,但是位置參數$6沒有,因此列印的就是個空字元。
01[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{print NF, }'024 d03[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";print va, }'04varA a b c d05[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";vb=6;print va, , vb, , 1}'06varA a b c d 6 1復制代碼
[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{print NF, }'4 d[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";print va, }'varA a b c d[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";vb=6;print va, , vb, , 1}'varA a b c d 6 1
4、使用sed中的s來進行替換,然後使用e命令來執行:
01[martin@TSPerPacketsTest]$ ls *Lan* | sed -r -n 's/(.*)Lan(.*)/mv & 1ch_Lan2/e'復制代碼
[martin@TSPerPacketsTest]$ ls *Lan* | sed -r -n 's/(.*)Lan(.*)/mv & 1ch_Lan2/e'
關於sed的選項,使用 -r和 -n
-r 來啟用後續可以使用 command,比如 mv
-n 來關閉 patten space中內容的顯示。
關於sed的 command,使用e。如此在使用s命令完成 pattern space中 Lan到 ch7_Lan的修改後,啟動shell來執行 pattern space中的' mv指令。
如果這里使用 p,標記僅僅顯示 pattern space中的指令而已。
如果對於某目錄下的所有文件,進行文件名修改,有兩種方式:
1、匯集awk的 FS/OFS和 gsub/system來實現。有點類似於綜合上述2,3兩種方式。
01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk 'BEGIN{FS="/";OFS="/"}{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'復制代碼
[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk 'BEGIN{FS="/";OFS="/"}{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'
為了實現所有目錄下的文件名進行修改,但是又不影響路徑上文件夾名。
首先,標記FS和OFS都為"/"。
其次,使用gsub時候,指定僅僅修改當前行中最後一個記錄,使用$NF來指定。
當然,對於FS和OFS的指定,可以不放置在 BEGIN中實現,比如:
01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -vF=/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'02[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -F/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'復制代碼
[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -vF=/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -F/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'
2、或者使用 sed。
01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | sed -r -n 's/(.*)([^/]*)Lan([^/]*)$/mv & 12ch7_Lan3/e'復制代碼
[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | sed -r -n 's/(.*)([^/]*)Lan([^/]*)$/mv & 12ch7_Lan3/e'
其中的各個 option和 command參數,上述都已經有介紹了。
這里,針對文件夾名和文件名,使用了簡單的sed內置的正則表達式來進行匹配而已,來實現僅僅對文件名的修改。
以上步驟在Linux修改文件名以及批量修改文件名的實現方式,是在shell中使用find、exec、xargs、mv命令組合批量替換文件名中的字元串。
❸ Linux 中如何運用awk截取文件名中部分內容
|經分析,文來件名自中以 ICIMSIDIFF 開頭,awk 中 可以考慮以它為分界符
試一下如下代碼:
ls -ltr *20100502* | awk -F "ICIMSIDIFF" '{print $2}'|cut -b 1-2
❹ linux 查找包含關鍵字的所有文件並刪除該文件。
|1、連接上相應的linux主機,進入到等待輸入shell指令的linux命令行狀態下。
❺ 如何編寫shell腳本將一個目錄下所有的文件的擴展名改為bak
尊重你的原亂槐有思路,修改代碼如下:
#!/bin/bash
dir=/root/lianxi
forfilein$dir/*
do
base=${file%.*}
mv$file${base}.bak
done
其中,${file%.*}表示去除文件擴展名,即最後一個點號及其後的所有內容。若不帶擴展名,如你例子中的4,則返回本身。
或者,for循環中也可以用sed直接替換得到新文件迅橡名:
newFile=$(echo嘩昌友$file|sed's/..*/.bak/')
mv$file$newFile
❻ linux 查找包含關鍵字的所有文件並刪除該文件。
find /var/www/html/tom -type f | xargs -n1 -I "ZZZZZ" grep -l "abc" "ZZZZZ" | xargs -n1 -I "XXXXX" rm -f "XXXXX"
其中,
ZZZZZ
和
XXXXX
都是臨時命名變數,你使用的時候直接這樣用就可以。不需要替換成別的字元。
前面2個回答,都是文件名中包含
abc
,而不是文件內容包含abc。所以,我的是正確的。
❼ linux下如何根據文件大小來清除文件內容
重定向吧~ 貌似Linux沒有獲取文件大小的函數吧,不太清楚
system("ls -l ss.log > file");
把文件的信息重定向到一個文件,然後讀該文件, 解析第5個字元串就知道文件的大小了~
超過100*1024*1024就system("rm ss.log");