উত্তর:
নীচে এক ডজন বা তার উদাহরণ রয়েছে যাতে আপনি কীভাবে কোনও ফাইল নিতে পারেন:
$ cat k.txt
1
2
3
এবং এই ফর্ম্যাট এ রূপান্তর:
1,2,3
উপরের ফাইলটি তৈরি করতে আপনি এই আদেশটি ব্যবহার করতে পারেন যদি আপনি পাশাপাশি খেলতে চান:
$ cat <<EOF > k.txt
1
2
3
EOF
নীচের উদাহরণগুলি 2 টি গ্রুপে বিভক্ত। যেগুলি "কাজ" করে এবং যারা "প্রায়" কাজ করে। আমি এগুলি ছেড়ে চলেছি কারণ প্রায়শই কেন কিছু কাজ করে না তা দেখার মতো মূল্যবান, কেন কিছু হয় তা দেখার জন্য।
আমি বেশিরভাগ স্ক্রিপ্টিং ভাষাগুলির প্রতিনিধিত্ব করি with কিছুগুলি একাধিকবার উপস্থাপিত হয়, যেহেতু সাধারণত পার্ল, টিমটোড্ডিআই-তে উল্লেখ করা বিখ্যাত সংক্ষিপ্ত বিবরণ হিসাবে ।
দ্রষ্টব্য: আপনি ,
নীচের উদাহরণগুলিতে কমা ( )) অদলবদল করতে পারেন এবং এটি আপনার পছন্দমতো অক্ষরের সাথে প্রতিস্থাপন করতে পারবেন, যেমন |
।
এই কোড স্নিপেটগুলি পছন্দসই আউটপুট উত্পাদন করবে।
paste
কমান্ড প্রয়োগ করুন:
$ paste -s -d ',' k.txt
1,2,3
sed
কমান্ড প্রয়োগ করুন:
$ sed ':a;N;$!ba;s/\n/,/g' k.txt
1,2,3
$ sed ':a;{N;s/\n/,/};ba' k.txt
1,2,3
perl
কমান্ড প্রয়োগ করুন:
$ perl -00 -p -e 's/\n(?!$)/,/g' k.txt
1,2,3
$ perl -00 -p -e 'chomp;tr/\n/,/' k.txt
1,2,3
awk
কমান্ড প্রয়োগ করুন:
$ awk '{printf"%s%s",c,$0;c=","}' k.txt
1,2,3
$ awk '{printf "%s,",$0}' k.txt | awk '{sub(/\,$/,"");print}'
1,2,3
$ awk -vORS=, 1 k.txt | awk '{sub(/\,$/,"");print}'
1,2,3
$ awk 'BEGIN {RS="dn"}{gsub("\n",",");print $0}' k.txt | awk '{sub(/\,$/,"");print}'
1,2,3
python
কমান্ড প্রয়োগ করুন:
$ python -c "import sys; print sys.stdin.read().replace('\n', ',')[0:-1]" <k.txt
1,2,3
$ python -c "import sys; print sys.stdin.read().replace('\n', ',').rstrip(',')" <k.txt
1,2,3
বাশের mapfile
অন্তর্নির্মিত:
$ mapfile -t a < k.txt; (IFS=','; echo "${a[*]}")
1,2,3
ruby
কমান্ড প্রয়োগ করুন:
$ ruby -00 -pe 'gsub /\n/,",";chop' < k.txt
1,2,3
$ ruby -00 -pe '$_.chomp!"\n";$_.tr!"\n",","' k.txt
1,2,3
php
কমান্ড প্রয়োগ করুন:
$ php -r 'echo strtr(chop(file_get_contents($argv[1])),"\n",",");' k.txt
1,2,3
আদেশ সহকারে
উপরের উদাহরণগুলির বেশিরভাগই ঠিক কাজ করবে। কারও কারও কাছে লুকানো সমস্যা রয়েছে যেমন উপরের পিএইচপি উদাহরণ। ফাংশনটি chop()
আসলে একটি উপনাম rtrim()
, সুতরাং শেষ লাইনের পিছনের স্থানগুলিও সরানো হবে।
প্রথম রুবির উদাহরণ এবং প্রথম পাইথনের উদাহরণটিও করুন। সমস্যাটি কীভাবে তারা সকলেই একটি ধরণের অপারেশন ব্যবহার করছে যা মূলত "চপস" বন্ধ করে দেয়, অন্ধভাবে, একটি চলন্ত চরিত্র। ওপি যে উদাহরণটি দিয়েছে তার উদাহরণ হিসাবে এটি ঠিক আছে, তবে এই ধরণের এক লাইনার ব্যবহার করার সময় তারা অবশ্যই প্রক্রিয়াজাত করা ডেটার সাথে সামঞ্জস্য রয়েছে তা নিশ্চিত করতে হবে।
উদাহরণ
আমাদের নমুনা ফাইলটি বলুন, k.txt
পরিবর্তে এর মতো দেখতে:
$ echo -en "1\n2\n3" > k.txt
এটি দেখতে অনুরূপ তবে এর মধ্যে কিছুটা পার্থক্য রয়েছে। \n
মূল ফাইলের মতো এটির পিছনে নতুন লাইন নেই ( )। এখন যখন আমরা প্রথম পাইথনের উদাহরণ চালাই আমরা এটি পাই:
$ python -c "import sys; print sys.stdin.read().replace('\n', ',')[0:-1]" <k.txt
1,2,
এগুলি হ'ল "সর্বদা এক বর, কখনও কনে না" উদাহরণ। তাদের বেশিরভাগই সম্ভবত অভিযোজিত হতে পারে, তবে কোনও সমস্যার সম্ভাব্য সমাধানের কাজ করার সময়, যখন এটি "জোরপূর্বক" বোধ করে, সম্ভবত এটি কাজের ভুল সরঞ্জাম!
perl
কমান্ড প্রয়োগ করুন:
$ perl -p -e 's/\n/,/' k.txt
1,2,3,
tr
কমান্ড প্রয়োগ করুন:
$ tr '\n' ',' < k.txt
1,2,3,
cat
+ + echo
কমান্ড:
$ echo $(cat k.txt)
1 2 3
ruby
কমান্ড প্রয়োগ করুন:
$ ruby -pe '$_["\n"]=","' k.txt
1,2,3,
বাশের while
+ read
বিল্ট-ইনগুলি:
$ while read line; do echo -n "$line,"; done < k.txt
1,2,3,
awk
আমি একটি সংক্ষিপ্ত বিকল্প পছন্দ:awk -vORS=, 1 k.txt
bash
:mapfile -t a < k.txt; (IFS=','; echo "${a[*]}")
perl
এবং প্রথম awk
তাদেরও আছে has
paste
। ঠিক এটাই paste -s
এখানে। এটি একটি স্ট্যান্ডার্ড কমান্ড এবং সবচেয়ে দক্ষ হবে। অন্য সমস্তগুলি ওভারকিল এবং / অথবা বহনযোগ্য নয় বা সীমাবদ্ধতা রয়েছে।
mapfile
তুলনামূলকভাবে নতুন, bash
4.0 এ যুক্ত হয়েছে ।
@ এসএলএম ইতিমধ্যে সুন্দর উত্তর দিয়েছে, তবে আপনার প্রশ্ন হিসাবে "xargs এর ফর্ম্যাট আউটপুট"
xargs -I{} echo -n "{}|" < test.txt
-I
"প্রতিস্থাপন স্ট্রিং" বিকল্প হয়।{}
আউটপুট পাঠ্যের জন্য একটি স্থানধারক।আপনি যদি পেছন থেকে মুক্তি পেতে চান তবে আপনি কিছু পরিষ্কার |
করতে ব্যবহার করতে পারেন sed
:
$ xargs -I{} echo -n "{}|" < k.txt | sed -e 's/|$//'
1|2|3
tr
, sed
এবং অন্যান্য এছাড়াও ..
এটি একটি পুরানো থ্রেড, আমি জানি। ওপির মতো একটি সাধারণ কোড সহ জিজ্ঞাসা করা হয়েছিল। এটি আসলটির কাছাকাছি রাখতে আমার একটি সহজ সমাধান রয়েছে।
cat k.txt | xargs
1 2 3
সেড ব্যবহার করুন
cat k.txt | xargs | sed 's/ /,/g'
1,2,3
অথবা
cat k.txt | xargs | sed 's/ /|/g'
1|2|3
সেড দেখতে কিছুটা অদ্ভুত তবে ভেঙে পড়েছে, এটি অনেক বেশি অর্থবোধ করে।
এর বিকল্প জন্য। g 'বিশ্বব্যাপী জন্য: এটি ছাড়া এটি প্রতিটি নতুন লাইনে কেবলমাত্র প্রথম প্রতিস্থাপন করবে do যেহেতু আপনি 'xargs' ব্যবহার করেন এটি এগুলিকে এক লাইন হিসাবে প্রদর্শন করে। সুতরাং আপনি "1,2 3" পাবেন।
ডিলিমিটারটি পৃথককরণের জন্য ব্যবহৃত হয়। আমি / চরিত্রটি ব্যবহার করেছি। একটি আকর্ষণীয় কৌশল: যতক্ষণ না আমরা এটিকে উদ্ধৃতিগুলির মধ্যে একই ফর্ম্যাটটি রাখি ততক্ষণ আপনি অন্য যে কোনও চরিত্রের সাথে ডিলিমিটারটি প্রতিস্থাপন করতে পারেন। সুতরাং এটি কাজ করবে ....
cat k.txt | xargs | sed 's# #,#g'
অথবা
cat k.txt | xargs | sed 'sT T,Tg'
স্পষ্টতই, ডেলিমিটার হিসাবে নির্দিষ্ট অক্ষরগুলি ব্যবহার করা বিভ্রান্তি পেতে পারে, তাই স্মার্ট হন।
xargs <k.txt | tr \ \|
আপনার যা দরকার তা না cat
- শুধু ফাইল ইনপুট মধ্যে পাস এবং - যদি অন্য কোন কমান্ড দেওয়া - xargs
সঙ্গে একটি ধরনের যা - তার ডিফল্ট বিন্যাস আউট পাস হবে /bin/echo
'র (ব্যাকস্ল্যাশ সি-পালাবার ব্যাখ্যা ছাড়া) ।
xargs
ইনপুট ফাইল থেকে মাথা / লেজ সাদা অংশ ছিনিয়ে নেবে এবং সাদা স্থানের অন্যান্য ক্রমগুলি একক স্থানের নিচে চেপে ধরবে। এর অর্থ এই যে থেকে ফাইল ক্ষণস্থায়ী যখন tr
থেকে xargs
মত:
tr \\n \| <k.txt | xargs
... কপি করে প্রিন্ট ...
1|2|3|
... যাচ্ছে অন্য উপায় এবং এর শুধুমাত্র অপারেটিং args যে xargs
স্থান-delimits করে ....
1|2|3\n
... কারণ xargs
চূড়ান্ত ট্রেলিং করা নতুন লাইনটি প্রিন্ট করে (যেমন কোনও পাঠ্য ফাইলের জন্য প্রয়োজনীয়) তবে এটি tr
সেভাবে উত্তর দেয় না ।
দ্রষ্টব্য, যদিও, এই (বা এখানে প্রস্তাবিত অন্য কোনও সমাধান)xargs
ইনপুট-এ উদ্ধৃতি দেওয়ার জন্য অ্যাকাউন্ট করে না । xargs
ইনপুটটিতে আক্ষরিকভাবে একক / ডাবল / ব্যাকস্ল্যাশ-উদ্ধৃত অ-নিউলাইন হোয়াইটস্পেস চরগুলি বের করে দেবে, যা তাদের নিজের মতো উদ্ধৃত করা যেতে পারে:
xargs <<\IN
1 2' 3'\' \'4
IN
1 2 3' '4
xargs cat -n
তবে আপনি যদি নতুন লাইনের চরিত্রগুলি কেবল ছাঁটাই করেন তবে এটি সহজ হয়echo $(cat)
,grep
বাawk
(এটি করার জন্য ক্রল করুন)।xargs
আপনার বর্তমান উদ্দেশ্যে ভাল ফিট না।