जवाबों:
नीचे एक दर्जन या तो उदाहरण दिए गए हैं कि आप इस तरह से फ़ाइल कैसे ले सकते हैं:
$ cat k.txt
1
2
3
और इसे इस प्रारूप में बदलें:
1,2,3
आप इस कमांड का उपयोग उपरोक्त फाइल बनाने के लिए कर सकते हैं यदि आप साथ खेलना चाहते हैं:
$ cat <<EOF > k.txt
1
2
3
EOF
नीचे दिए गए उदाहरण 2 समूहों में विभाजित हैं। "काम" और लोगों को "लगभग" काम करने वाले लोग। मैं इन्हें छोड़ देता हूं क्योंकि अक्सर यह देखने के लिए मूल्यवान होता है कि कुछ काम क्यों नहीं करता है, क्योंकि यह देखना है कि कुछ क्यों करता है।
अधिकांश स्क्रिप्टिंग भाषाएं जिनसे मैं परिचित हूं उनका प्रतिनिधित्व किया जाता है। कुछ को कई बार दर्शाया जाता है, क्योंकि आमतौर पर पर्ल, TIMTOWTDI में संदर्भित प्रसिद्ध संक्षिप्त नाम के साथ ।
नोट: आप ,
नीचे दिए गए उदाहरणों में अल्पविराम ( ) को स्वैप कर सकते हैं और इसे अपने इच्छित वर्णों के साथ बदल सकते हैं, अर्थात |
।
ये कोड स्निपेट्स वांछित आउटपुट का उत्पादन करेंगे।
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
चेतावनियां
ऊपर दिए गए ज्यादातर उदाहरण ठीक काम करेंगे। कुछ में छिपे हुए मुद्दे हैं, जैसे ऊपर PHP उदाहरण। फ़ंक्शन chop()
वास्तव में एक उपनाम है rtrim()
, इसलिए अंतिम पंक्ति के अनुगामी रिक्त स्थान को भी हटा दिया जाएगा।
तो भी पहला रूबी उदाहरण है, और पहला पायथन उदाहरण है। मुद्दा यह है कि वे सभी किस प्रकार के ऑपरेशन का उपयोग कर रहे हैं जो अनिवार्य रूप से "चॉप" करते हैं, नेत्रहीन, एक अनुगामी चरित्र। यह उदाहरण के लिए ठीक है कि ओपी ने प्रदान किया, लेकिन इस प्रकार के एक लाइनर का उपयोग करते समय ध्यान रखना चाहिए कि वे उस डेटा के अनुरूप हैं जो वे प्रसंस्करण कर रहे हैं।
उदाहरण
हमारी नमूना फ़ाइल कहें, k.txt
इसके बजाय इस तरह दिखती है:
$ echo -en "1\n2\n3" > k.txt
यह समान दिखता है लेकिन इसमें एक मामूली अंतर है। यह \n
मूल फ़ाइल की तरह एक अनुगामी newline ( ) नहीं है । अब जब हम पहला पायथन उदाहरण चलाते हैं तो हमें यह मिलता है:
$ 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
उनके पास भी है।
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
sed का उपयोग करें
cat k.txt | xargs | sed 's/ /,/g'
1,2,3
या
cat k.txt | xargs | sed 's/ /|/g'
1|2|3
सिड थोड़ा अजीब लग सकता है लेकिन टूट गया है, यह बहुत समझ में आता है।
के विकल्प के लिए है। g 'वैश्विक के लिए है: इसके बिना, यह केवल प्रत्येक नई पंक्ति पर पहला प्रतिस्थापन करेगा। चूंकि आप '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|
... जा रहा दूसरा रास्ता और पर केवल ऑपरेटिंग आर्ग कि xargs
अंतरिक्ष delimits करता है ....
1|2|3\n
... क्योंकि xargs
अंतिम अनुगामी newline (जैसा कि एक पाठ फ़ाइल के लिए आवश्यक है) प्रिंट करता है, लेकिन यह tr
उस तरह से anslated नहीं मिलता है ।
ध्यान दें, हालांकि, यह (या यहां प्रस्तुत कोई अन्य समाधान)xargs
इनपुट में उद्धृत करने के लिए जिम्मेदार नहीं है । xargs
इनपुट में शाब्दिक रूप से सिंगल / डबल / बैकस्लैश-कोटेड नॉन-न्यूलाइन व्हॉट्सएप चार्ट पास करेगा, जिसे स्वयं उद्धृत किया जा सकता है:
xargs <<\IN
1 2' 3'\' \'4
IN
1 2 3' '4
xargs cat -n
, लेकिन अगर आप सिर्फ नए अक्षरों को ट्रिम करते हैं, तो इसे हासिल किया जा सकता हैecho $(cat)
,grep
याawk
इसे करने का तरीका क्रॉल कर सकते हैं)।xargs
अपने वर्तमान उद्देश्य के लिए अच्छी तरह से फिट नहीं है।