টার্মিনালে, আমি কীভাবে এক্স বাইটের চেয়ে বড় বা ছোট ফাইলগুলি সন্ধান করতে পারি?
আমি মনে করি আমি এরকম কিছু করতে পারি
find . -exec ls -l {} \;
এবং তারপরে ফলাফলটি awkফাইল আকারে ফিল্টার করতে পাইপ করুন । তবে এর চেয়ে সহজ উপায় আর কি হওয়া উচিত নয়?
টার্মিনালে, আমি কীভাবে এক্স বাইটের চেয়ে বড় বা ছোট ফাইলগুলি সন্ধান করতে পারি?
আমি মনে করি আমি এরকম কিছু করতে পারি
find . -exec ls -l {} \;
এবং তারপরে ফলাফলটি awkফাইল আকারে ফিল্টার করতে পাইপ করুন । তবে এর চেয়ে সহজ উপায় আর কি হওয়া উচিত নয়?
উত্তর:
ব্যবহার করুন:
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.
আমি মনে করি findAWK- এ পাইপ না করে একা কার্যকর হতে পারে। উদাহরণ স্বরূপ,
find ~ -type f -size +2k -exec ls -sh {} \;
টিলড নির্দেশ করে যে আপনি কোথায় নিজের সন্ধান শুরু করতে চান এবং ফলাফলটি কেবল 2 কিলোবাইটের বেশি ফাইল প্রদর্শন করবে।
এটিকে অভিনব করতে, আপনি -execঅন্য একটি কমান্ড কার্যকর করতে অপশনটি ব্যবহার করতে পারেন যা তাদের ডিরেক্টরিতে ডিরেক্টরিগুলি তালিকাভুক্ত করে।
আরও তথ্যের জন্য, ম্যান পৃষ্ঠাটি পড়ুন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} '