Linux中如何查找最大的10個(gè)文件方法
有時(shí)我們需要在Linux下查找文件哪個(gè)最大,便于管理,這篇文章主要給大家介紹了關(guān)于在Linux中如何查找最大的10個(gè)文件的一些方法,文中分別給大家介紹了四種方法需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
方法 1
在 Linux 中沒(méi)有特定的命令可以直接執(zhí)行此操作,因此我們需要將多個(gè)命令結(jié)合使用。
# find / -type f -print0 | xargs -0 du -h | sort -rh | head -n 10
1.4G /swapfile
1.1G /home/magi/ubuntu-17.04-desktop-amd64.iso
564M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
378M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
377M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
100M /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
93M /usr/lib/firefox/libxul.so
84M /var/lib/snapd/snaps/core_3604.snap
84M /var/lib/snapd/snaps/core_3440.snap
84M /var/lib/snapd/snaps/core_3247.snap
詳解:
find:在目錄結(jié)構(gòu)中搜索文件的命令
/:在整個(gè)系統(tǒng)(從根目錄開(kāi)始)中查找
-type:指定文件類(lèi)型
f:普通文件
-print0:在標(biāo)準(zhǔn)輸出顯示完整的文件名,其后跟一個(gè)空字符(null)
|:控制操作符,將一條命令的輸出傳遞給下一個(gè)命令以供進(jìn)一步處理
xargs:將標(biāo)準(zhǔn)輸入轉(zhuǎn)換成命令行參數(shù)的命令
-0:以空字符(null)而不是空白字符(LCTT 譯者注:即空格、制表符和換行)來(lái)分割記錄
du -h:以可讀格式計(jì)算磁盤(pán)空間使用情況的命令
sort:對(duì)文本文件進(jìn)行排序的命令
-r:反轉(zhuǎn)結(jié)果
-h:用可讀格式打印輸出
head:輸出文件開(kāi)頭部分的命令
n -10:打印前 10 個(gè)文件
方法 2
這是查找 Linux 系統(tǒng)中最大的前 10 個(gè)文件的另一種方法。我們依然使用多個(gè)命令共同完成這個(gè)任務(wù)。
# find / -type f -exec du -Sh {} + | sort -rh | head -n 10
1.4G /swapfile
1.1G /home/magi/ubuntu-17.04-desktop-amd64.iso
564M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
378M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
377M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
100M /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
93M /usr/lib/firefox/libxul.so
84M /var/lib/snapd/snaps/core_3604.snap
84M /var/lib/snapd/snaps/core_3440.snap
84M /var/lib/snapd/snaps/core_3247.snap
詳解:
find:在目錄結(jié)構(gòu)中搜索文件的命令
/:在整個(gè)系統(tǒng)(從根目錄開(kāi)始)中查找
-type:指定文件類(lèi)型
f:普通文件
-exec:在所選文件上運(yùn)行指定命令
du:計(jì)算文件占用的磁盤(pán)空間的命令
-S:不包含子目錄的大小
-h:以可讀格式打印
{}:遞歸地查找目錄,統(tǒng)計(jì)每個(gè)文件占用的磁盤(pán)空間
|:控制操作符,將一條命令的輸出傳遞給下一個(gè)命令以供進(jìn)一步處理
sort:對(duì)文本文件進(jìn)行按行排序的命令
-r:反轉(zhuǎn)結(jié)果
-h:用可讀格式打印輸出
head:輸出文件開(kāi)頭部分的命令
n -10:打印前 10 個(gè)文件
方法 3
這里介紹另一種在 Linux 系統(tǒng)中搜索最大的前 10 個(gè)文件的方法。
# find / -type f -print0 | xargs -0 du | sort -n | tail -10 | cut -f2 | xargs -I{} du -sh {}
84M /var/lib/snapd/snaps/core_3247.snap
84M /var/lib/snapd/snaps/core_3440.snap
84M /var/lib/snapd/snaps/core_3604.snap
93M /usr/lib/firefox/libxul.so
100M /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
377M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
378M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
564M /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
1.1G /home/magi/ubuntu-17.04-desktop-amd64.iso
1.4G /swapfile
詳解:
find:在目錄結(jié)構(gòu)中搜索文件的命令
/:在整個(gè)系統(tǒng)(從根目錄開(kāi)始)中查找
-type:指定文件類(lèi)型
f:普通文件
-print0:輸出完整的文件名,其后跟一個(gè)空字符(null)
|:控制操作符,將一條命令的輸出傳遞給下一個(gè)命令以供進(jìn)一步處理
xargs:將標(biāo)準(zhǔn)輸入轉(zhuǎn)換成命令行參數(shù)的命令
-0:以空字符(null)而不是空白字符來(lái)分割記錄
du:計(jì)算文件占用的磁盤(pán)空間的命令
sort:對(duì)文本文件進(jìn)行按行排序的命令
-n:根據(jù)數(shù)字大小進(jìn)行比較
tail -10:輸出文件結(jié)尾部分的命令(最后 10 個(gè)文件)
cut:從每行刪除特定部分的命令
-f2:只選擇特定字段值
-I{}:將初始參數(shù)中出現(xiàn)的每個(gè)替換字符串都替換為從標(biāo)準(zhǔn)輸入讀取的名稱(chēng)
-s:僅顯示每個(gè)參數(shù)的總和
-h:用可讀格式打印輸出
{}:遞歸地查找目錄,統(tǒng)計(jì)每個(gè)文件占用的磁盤(pán)空間
方法 4
還有一種在 Linux 系統(tǒng)中查找最大的前 10 個(gè)文件的方法。
# find / -type f -ls | sort -k 7 -r -n | head -10 | column -t | awk '{print $7,$11}'
1494845440 /swapfile
1085984380 /home/magi/ubuntu-17.04-desktop-amd64.iso
591003648 /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqTFU0XzkzUlJUZzA
395770383 /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqeldzUmhPeC03Zm8
394891761 /home/magi/.gdfuse/magi/cache/0B5nso_FPaZFqRGd4V0VrOXM4YVU
103999072 /usr/lib/x86_64-linux-gnu/libOxideQtCore.so.0
97356256 /usr/lib/firefox/libxul.so
87896064 /var/lib/snapd/snaps/core_3604.snap
87793664 /var/lib/snapd/snaps/core_3440.snap
87089152 /var/lib/snapd/snaps/core_3247.snap
詳解:
find:在目錄結(jié)構(gòu)中搜索文件的命令
/:在整個(gè)系統(tǒng)(從根目錄開(kāi)始)中查找
-type:指定文件類(lèi)型
f:普通文件
-ls:在標(biāo)準(zhǔn)輸出中以 ls -dils 的格式列出當(dāng)前文件
|:控制操作符,將一條命令的輸出傳遞給下一個(gè)命令以供進(jìn)一步處理
sort:對(duì)文本文件進(jìn)行按行排序的命令
-k:按指定列進(jìn)行排序
-r:反轉(zhuǎn)結(jié)果
-n:根據(jù)數(shù)字大小進(jìn)行比較
head:輸出文件開(kāi)頭部分的命令
-10:打印前 10 個(gè)文件
column:將其輸入格式化為多列的命令
-t:確定輸入包含的列數(shù)并創(chuàng)建一個(gè)表
awk:模式掃描和處理語(yǔ)言
'{print $7,$11}':只打印指定的列
補(bǔ)充:Linux基本命令
?、賚s 意為list 列出當(dāng)前文件夾中的文件
-l 顯示文件的屬性 可用ll來(lái)表示
?、赼lias 別名 看看是否有別名的文件
③cd dir 跳躍目錄 -P選項(xiàng) 將路徑中的鏈接文件替換成鏈接指向的文件路徑
?、躳wd 查看當(dāng)前工作的文件夾名 使用-P的選項(xiàng),會(huì)直接進(jìn)入到其中,相當(dāng)于cd
相關(guān)閱讀:Linuxshell腳本不執(zhí)行問(wèn)題實(shí)例分析
shell腳本不執(zhí)行問(wèn)題:某天研發(fā)某同事找我說(shuō)幫他看看他寫(xiě)的shell腳本,死活不執(zhí)行,報(bào)錯(cuò)。我看了下,腳本很簡(jiǎn)單,也沒(méi)有常規(guī)性的錯(cuò)誤,報(bào)“:badinterpreter:Nosuchfileordirectory”錯(cuò)??催@錯(cuò),我就問(wèn)他是不是在windows下編寫(xiě)的腳本,然后在上傳到linux服務(wù)器的……果然。原因:在DOS/windows里,文本文件的換行符為rn,而在*nix系統(tǒng)里則為n,所以DOS/Windows里編輯過(guò)的文本文件到了*nix里,每一行都多了個(gè)^M。解決:
1)重新在linux下編寫(xiě)腳本;
2)vi:%s/r//g:%s/^M//g(^M輸入用Ctrl+v,Ctrl+m)附:sh-x腳本文件名,可以單步執(zhí)行并回顯結(jié)果,有助于排查復(fù)雜腳本問(wèn)題。
Linux中如何查找最大的10個(gè)文件方法相關(guān)文章:
1.Linux系統(tǒng)下怎么查找可執(zhí)行文件