আপনি দুটি খুব ভিন্ন ধরণের ইনপুট বিভ্রান্ত করছেন: STDIN এবং যুক্তি। আর্গুমেন্টগুলি কমান্ডের শুরু হওয়া স্ট্রিংয়ের একটি তালিকা যা সাধারণত কমান্ডের নাম (যেমন echo these are some arguments
বা rm file1 file2
) এর পরে নির্দিষ্ট করে থাকে । অন্যদিকে, স্টাডিন হ'ল বাইটের একটি ধারা (কখনও কখনও পাঠ্য, কখনও কখনও না) যা কমান্ডটি শুরু করার পরে (allyচ্ছিকভাবে) পড়তে পারে। এখানে কয়েকটি উদাহরণ দেওয়া আছে (নোট যেটি cat
আর্গুমেন্ট বা STDIN নিতে পারে তবে এটি তাদের সাথে বিভিন্ন জিনিস করে):
echo file1 file2 | cat # Prints "file1 file2", since that's the stream of
# bytes that echo passed to cat's STDIN
cat file1 file2 # Prints the CONTENTS of file1 and file2
echo file1 file2 | rm # Prints an error message, since rm expects arguments
# and doesn't read from STDIN
xargs
STDIN- স্টাইল ইনপুটকে আর্গুমেন্টে রূপান্তরকারী হিসাবে ভাবা যেতে পারে:
echo file1 file2 | cat # Prints "file1 file2"
echo file1 file2 | xargs cat # Prints the CONTENTS of file1 and file2
echo
আসলে কম-বেশি বা বিপরীতটি খুব কম করে: এটি তার যুক্তিগুলিকে STDOUT- এ রূপান্তর করে (যা অন্য কোনও কমান্ডের STDIN এ পাইপ করা যেতে পারে):
echo file1 file2 | echo # Prints a blank line, since echo doesn't read from STDIN
echo file1 file2 | xargs echo # Prints "file1 file2" -- the first echo turns
# them from arguments into STDOUT, xargs turns
# them back into arguments, and the second echo
# turns them back into STDOUT
echo file1 file2 | xargs echo | xargs echo | xargs echo | xargs echo # Similar,
# except that it converts back and forth between
# args and STDOUT several times before finally
# printing "file1 file2" to STDOUT.
ls | grep -v "notes.txt" | xargs rm
ব্যতীত সমস্ত কিছুই সরানোর জন্য ব্যবহার করা উচিত নয়notes.txt
বা সাধারণভাবে কখনইls
আউটপুটকে বিশ্লেষণ করতে পারে না । উদাহরণস্বরূপ, যদি কোনও একক ফাইলের মধ্যে একটি জায়গা থাকে তবে আপনার আদেশটি ভঙ্গ হবে। নিরাপদ উপায়েrm !(notes.txt)
বাশ (shopt -s extglob
সেট সহ), বাrm ^notes.txt
জেডশ (সহEXTENDED_GLOB
) ইত্যাদি হবে