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