ටර්මිනලයක, x බයිට් වලට වඩා විශාල හෝ කුඩා ගොනු සොයා ගන්නේ කෙසේද?
මම හිතන්නේ මට ඒ වගේ දෙයක් කරන්න පුළුවන්
find . -exec ls -l {} \;
ඉන්පසු awk
ගොනුවේ ප්රමාණය අනුව පෙරීමට ප්රති result ලය නල කරන්න . නමුත් මීට වඩා පහසු ක්රමයක් තිබිය යුතු නොවේද?
ටර්මිනලයක, x බයිට් වලට වඩා විශාල හෝ කුඩා ගොනු සොයා ගන්නේ කෙසේද?
මම හිතන්නේ මට ඒ වගේ දෙයක් කරන්න පුළුවන්
find . -exec ls -l {} \;
ඉන්පසු awk
ගොනුවේ ප්රමාණය අනුව පෙරීමට ප්රති result ලය නල කරන්න . නමුත් මීට වඩා පහසු ක්රමයක් තිබිය යුතු නොවේද?
Answers:
භාවිත:
find . -type f -size +4096c
බයිට් 4096 ට වඩා විශාල ගොනු සොයා ගැනීමට.
හා :
find . -type f -size -4096c
බයිට් 4096 ට වඩා කුඩා ගොනු සොයා ගැනීමට.
ප්රමාණයේ ස්විචයෙන් පසු + සහ - වෙනස සැලකිල්ලට ගන්න.
මෙම -size
ස්විචය මෙසේ පැහැදිලි කලේ ය:
-size n[cwbkMG]
File uses n units of space. The following suffixes can be used:
`b' for 512-byte blocks (this is the default if no suffix is
used)
`c' for bytes
`w' for two-byte words
`k' for Kilobytes (units of 1024 bytes)
`M' for Megabytes (units of 1048576 bytes)
`G' for Gigabytes (units of 1073741824 bytes)
The size does not count indirect blocks, but it does count
blocks in sparse files that are not actually allocated. Bear in
mind that the `%k' and `%b' format specifiers of -printf handle
sparse files differently. The `b' suffix always denotes
512-byte blocks and never 1 Kilobyte blocks, which is different
to the behaviour of -ls.
මම හිතන්නේ find
AWK වෙත නල මාර්ගයක් නොමැතිව තනිවම ප්රයෝජනවත් වේවි. උදාහරණයක් වශයෙන්,
find ~ -type f -size +2k -exec ls -sh {} \;
ටිල්ඩ් මඟින් ඔබේ සෙවීම ආරම්භ කිරීමට අවශ්ය ස්ථානය පෙන්වන අතර ප්රති result ලය පෙන්විය යුත්තේ කිලෝබයිට් 2 ට වඩා වැඩි ගොනු පමණි.
එය මන ancy කල්පිත කිරීමට, ඔබට -exec
වෙනත් විධානයක් ක්රියාත්මක කිරීමට විකල්පය භාවිතා කළ හැකිය, එනම් මෙම නාමාවලි ඒවායේ ප්රමාණයන් සමඟ ලැයිස්තු ගත කිරීමයි.
වැඩි විස්තර සඳහා, man පිටුවfind
කියවන්න .
AWK ඇත්තටම මේ වගේ දෙයක් සඳහා සෑහෙන්න පහසුයි. ඔබ ඇසූ පරිදි ගොනු ප්රමාණ පරික්ෂා කිරීම සම්බන්ධයෙන් ඔබට එය කළ හැකි කරුණු කිහිපයක් මෙන්න:
බයිට් 200 ට වඩා වැඩි ගොනු ලැයිස්තුගත කරන්න:
ls -l | awk '{if ($5 > 200) print $8}'
බයිට් 200 ට අඩු ගොනු ලැයිස්තුගත කර ලැයිස්තුව ගොනුවකට ලියන්න:
ls -l | awk '{if ($5 < 200) print $8}' | tee -a filelog
බයිට් 0 ක ගොනු ලැයිස්තුගත කරන්න, ලැයිස්තුව ගොනුවකට පටිගත කර හිස් ගොනු මකන්න:
ls -l | awk '{if ($5 == 0) print $8}' | tee -a deletelog | xargs rm
tee
වැනි ගොනුවකට පයිප්ප දැමීම සහ යලි හරවා යැවීම අතර වෙනස කුමක්ද? ls -l > filelog
ls -l >> filelog
බයිට් 2000 ට වඩා විශාල:
du -a . | awk '$1*512 > 2000 {print $2}'
බයිට් 2000 ට අඩු:
du -a . | awk '$1*512 < 2000 {print $2} '