TL; ড
একমাত্র আপনার stuff
পক্ষে সম্ভবত কাজ করবে।
পুরো উত্তর
কি ঘটেছে
আপনি যখন দৌড়ান foo $(stuff)
, এটি ঘটে যা ঘটে:
stuff
রান;
- এর আউটপুট (stdout), মুদ্রণের পরিবর্তে, এর অনুরোধে প্রতিস্থাপন
$(stuff)
করে foo
;
- তারপরে
foo
চলে, তার কমান্ড লাইনের যুক্তিগুলি স্পষ্টতই stuff
ফিরে আসে তার উপর নির্ভর করে ।
এই $(…)
প্রক্রিয়াটিকে "কমান্ড সাবস্টিটিউশন" বলা হয়। আপনার ক্ষেত্রে প্রধান কমান্ড হ'ল echo
মূলত স্ট্যান্ডআউটে তার কমান্ড লাইন আর্গুমেন্টগুলি মুদ্রণ করে। তাই যাই হোক না কেন stuff
stdout- এ মুদ্রণ করার চেষ্টা করে বন্দী, এর পাস করা হয়েছে echo
এবং stdout- এ মুদ্রিত echo
।
আপনি যদি আউটপুটটি stuff
স্টডআউটে মুদ্রিত হতে চান তবে কেবল একক চালান stuff
।
`…`
সিনট্যাক্স হিসাবে একই উদ্দেশ্য করে তোলে $(…)
(একই নামের অধীনে: "কমান্ড প্রতিকল্পন"), তাই এগুলোকে অন্ধের মত না অদলবদল করতে পারেন, যদিও কয়েক পার্থক্য আছে। দেখুন এই FAQ এবং এই প্রশ্নের ।
আমি echo $(stuff)
কি যাই হোক না কেন এড়ানো উচিত?
echo $(stuff)
আপনি কী করছেন তা যদি জানেন তবে আপনি ব্যবহার করতে পারেন এমন একটি কারণ রয়েছে । echo $(stuff)
আপনি কী করছেন তা যদি সত্যিই না জানেন তবে একই কারণে আপনার এড়ানো উচিত ।
বিষয়টি হ'ল stuff
এবং echo $(stuff)
সমতুল্য নয়। পরবর্তীটির অর্থ হ'ল stuff
ডিফল্ট মান সহ আউটপুটে স্প্লিট + গ্লোব অপারেটর কল করা $IFS
। কমান্ড প্রতিস্থাপনের ডাবল উদ্ধৃতি এটি প্রতিরোধ করে। একক কমান্ড সাবস্টিটিউশন উদ্ধৃত করার ফলে এটি আর কমান্ডের বিকল্প হতে পারে না।
বিভাজন আসে যখন এই কমান্ডগুলি চালানোর জন্য এটি পর্যবেক্ষণ:
echo "a b"
echo $(echo "a b")
echo "$(echo "a b")" # the shell is smart enough to identify the inner and outer quotes
echo '$(echo "a b")'
এবং গ্লোব্বিংয়ের জন্য:
echo "/*"
echo $(echo "/*")
echo "$(echo "/*")" # the shell is smart enough to identify the inner and outer quotes
echo '$(echo "/*")'
যেমন আপনি দেখতে পাচ্ছেন echo "$(stuff)"
এটি সমান (-শ *) stuff
। আপনি এটি ব্যবহার করতে পারেন তবে জিনিসগুলিকে এভাবে জটিল করার উপায় কী?
অন্যদিকে যদি আপনি চান আউটপুট stuff
বিভাজন + + globbing তারপর আপনি ভুগা পারে এটি echo $(stuff)
দরকারী। যদিও এটি আপনার সচেতন সিদ্ধান্ত হতে হবে।
কমান্ডগুলি উত্পন্ন করার আউটপুট রয়েছে যা মূল্যায়ন করা উচিত (যার মধ্যে বিভাজন, গ্লোব্বিং এবং আরও অনেক কিছু রয়েছে) এবং শেল দ্বারা চালিত হয়, তাই eval "$(stuff)"
সম্ভাবনা রয়েছে ( এই উত্তরটি দেখুন )। আমি কোনও কমান্ড কখনই দেখিনি যা মুদ্রণের আগে অতিরিক্ত বিভাজন + গ্লোব্বিংয়ের মধ্য দিয়ে আউটপুটটির প্রয়োজন হয় । ইচ্ছাকৃতভাবে ব্যবহার করা echo $(stuff)
খুব অস্বাভাবিক মনে হচ্ছে।
কি হবে var=$(stuff); echo "$var"
?
ভাল যুক্তি. এই স্নিপেট:
var=$(stuff)
echo "$var"
echo "$(stuff)"
সমান (-শ *) এর সমতুল্য হওয়া উচিত stuff
। এটি যদি পুরো কোড হয় তবে কেবল stuff
তার পরিবর্তে চালান ।
তবে, যদি আপনাকে stuff
একাধিকবার আউটপুট ব্যবহার করতে হয় তবে এই পদ্ধতির
var=$(stuff)
foo "$var"
bar "$var"
সাধারণত তুলনায় ভাল
foo "$(stuff)"
bar "$(stuff)"
এমনকি যদি foo
হয় echo
এবং আপনি echo "$var"
আপনার কোডটি পেয়ে থাকেন তবে এটিকে এভাবে রাখাই ভাল। বিবেচনা করার বিষয়গুলি:
var=$(stuff)
stuff
একবার রান দিয়ে ; কমান্ডটি দ্রুত হলেও, একই আউটপুট দু'বার গণনা করা এড়ানো সঠিক জিনিস। অথবা stuff
স্টাডাউটে লেখার ব্যতীত অন্য কোনও প্রভাব থাকতে পারে (যেমন একটি অস্থায়ী ফাইল তৈরি করা, একটি পরিষেবা শুরু করা, ভার্চুয়াল মেশিন শুরু করা, রিমোট সার্ভারকে অবহিত করা), যাতে আপনি এটি একাধিকবার চালাতে চান না।
- যদি
stuff
সময় নির্ভর বা কিছুটা এলোমেলো আউটপুট উত্পন্ন করে তবে আপনি foo "$(stuff)"
এবং থেকে বেমানান ফলাফল পেতে পারেন bar "$(stuff)"
। var=$(stuff)
এর মান $var
স্থির হওয়ার পরে এবং আপনি নিশ্চিত হতে পারেন foo "$var"
এবং bar "$var"
অভিন্ন কমান্ড লাইন যুক্তি পেতে পারেন ।
কিছু ক্ষেত্রে আপনার পরিবর্তে foo "$var"
(প্রয়োজন) ব্যবহার করতে চান foo $var
, বিশেষত যদি একাধিক যুক্তি stuff
উত্পন্ন করেfoo
(আপনার শেল সমর্থন করে তবে একটি অ্যারে ভেরিয়েবল আরও ভাল হতে পারে)। আবার, আপনি কি করছেন তা জানুন। এটা আসে যখন echo
এর মধ্যে পার্থক্য echo $var
এবং echo "$var"
মধ্যবর্তী হিসাবে একই echo $(stuff)
এবং echo "$(stuff)"
।
* সমান ( -শ )?
আমি বললাম echo "$(stuff)"
সমতূল্য (পর) হল stuff
। কমপক্ষে দুটি সমস্যা রয়েছে যা একে একে একে সমান নয়:
$(stuff)
stuff
একটি সাব-শেলের মধ্যে চলে , সুতরাং echo "$(stuff)"
সমতুল্য (-শ) বললে ভাল (stuff)
। কমান্ডগুলি যেগুলি চালিত শেলকে প্রভাবিত করে, যদি সাব-শেলতে থাকে তবে মূল শেলটিকে প্রভাবিত করবে না।
এই উদাহরণে stuff
হয় a=1; echo "$a"
:
a=0
echo "$(a=1; echo "$a")" # echo "$(stuff)"
echo "$a"
এর সাথে তুলনা করুন
a=0
a=1; echo "$a" # stuff
echo "$a"
এবং সাথে
a=0
(a=1; echo "$a") # (stuff)
echo "$a"
আর একটি উদাহরণ, stuff
সত্তা দিয়ে শুরু করুন cd /; pwd
:
cd /bin
echo "$(cd /; pwd)" # echo "$(stuff)"
pwd
এবং পরীক্ষা stuff
এবং (stuff)
সংস্করণ।
echo
অনিয়ন্ত্রিত ডেটা প্রদর্শনের জন্য কোনও ভাল সরঞ্জাম নয় । এই echo "$var"
আমরা কথা বলছিলাম উচিত ছিল printf '%s\n' "$var"
। তবে যেহেতু প্রশ্নের উল্লেখ রয়েছে echo
এবং যেহেতু সবচেয়ে সম্ভাব্য সমাধানটি echo
প্রথম স্থানে ব্যবহার না করা হয়েছে , তাই printf
এখন অবধি পরিচয় না করানোর সিদ্ধান্ত নিয়েছি ।
stuff
অথবা (stuff)
স্টলআউট এবং স্টডার আউটপুট ইন্টারলিভ করবে, যখন echo $(stuff)
সমস্ত স্টডার আউটপুট মুদ্রণ করবে stuff
(যা প্রথমে চলে) এবং কেবল তখনই স্টাডআউট আউটপুট হজম করে echo
(যা শেষ চলে)।
$(…)
যেকোন পেছনের নতুন লাইনটি স্ট্রিপ করে এবং তারপরে echo
এটি আবার যুক্ত করে। সুতরাং echo "$(printf %s 'a')" | xxd
বিভিন্ন আউটপুট দেয় printf %s 'a' | xxd
।
কিছু কমান্ড ( ls
উদাহরণস্বরূপ) স্ট্যান্ডার্ড আউটপুট কনসোল কিনা তা নির্ভর করে ভিন্নভাবে কাজ করে; সুতরাং ls | cat
একই ls
করে না। একইভাবে echo $(ls)
ভিন্ন চেয়ে কাজ করবে ls
।
ফেলে ls
একটি সাধারণ ক্ষেত্রে সরাইয়া, যদি আপনি জোর করে অন্য আচরণ তারপর আছে stuff | cat
বেশী ভালো echo $(ls)
বা echo "$(ls)"
কারণ এটি আরম্ভ না সব অন্যান্য বিষয় এখানে উল্লেখ করেছে।
সম্ভবত পৃথক প্রস্থান স্থিতি (এই উইকির উত্তরটির সম্পূর্ণতার জন্য উল্লেখ করা হয়েছে; বিশদগুলির জন্য আরও একটি উত্তর দেখুন যা creditণের দাবি রাখে)।