शेल स्क्रिप्ट का उपयोग करके स्तंभित फ़ाइल में पाठ फ़ाइल में मान कैसे प्रिंट करें


11

मेरे पास एक आउटपुट स्क्रिप्ट है। शेल स्क्रिप्ट चलाने के लिए निम्नानुसार है:

abc.txt
errorstatus1
Fri Nov 11 02:00:09 2016
def.txt
errorstatus2.txt
Sat Nov 12 03:00:09 2016

पाठ फ़ाइल में एक ही तरीके से कई प्रविष्टियाँ लाइन द्वारा होती हैं। मैं इन मूल्यों को स्तंभों में मुद्रित करना चाहता हूं: फ़ाइलनाम, स्थिति और टाइमस्टैम्प निम्नानुसार हैं:

Filename      Status        Timestamp
abc.txt     errorstatus1   Fri Nov 11 02:00:09 2016
def.txt     errorstatus2   Sat Nov 12 03:00:09 2016

4
उदाहरण स्वरूप CSV फ़ाइल नहीं है, यह एक निश्चित-स्तंभ-चौड़ाई वाली फ़ाइल है। आप प्रश्न को स्पष्ट करना चाहते हैं या एक सही उदाहरण प्रदान करना चाहते हैं।
एलेक्सपी

आपका उदाहरण सीवीएस प्रारूप नहीं है। सीवीएस प्रारूप है abc.txt,errorstatus1,Fri Nov 11 02:00:09 2016। मैंने आपके प्रश्न को मिलान करने के लिए संपादित किया कि यह आपके द्वारा दिए गए उदाहरण के साथ क्या कहता है। वापस रोल करने के लिए स्वतंत्र महसूस करें, लेकिन कृपया ध्यान दें कि आपको वास्तव में स्पष्ट करने की आवश्यकता है कि आप वास्तव में क्या चाहते हैं - स्तंभित मूल्य या अल्पविराम से अलग किए गए मान
Sergiy Kolodyazhnyy

जवाबों:


14

के साथ paste:

paste - - - <file.txt

यह नईलाइन से अलग की गई फ़ाइल सामग्री को कॉलम के रूप में आउटपुट करेगा, और प्रति पंक्ति तीन टैब अलग कॉलम।

शीर्ष लेख जोड़ना:

echo Filename Status Timestamp; paste - - - <file.txt

आउटपुट को स्तंभित करने के लिए, इसकी सहायता लें column:

{ echo Filename Status Timestamp; paste - - - <file.txt ;} | column -t

उदाहरण:

% cat file.txt
abc.txt
errorstatus1
Fri Nov 11 02:00:09 2016
def.txt
errorstatus2.txt
Sat Nov 12 03:00:09 2016

% { echo Filename Status Timestamp; paste - - - <file.txt ;} | column -t
Filename  Status            Timestamp
abc.txt   errorstatus1      Fri        Nov  11  02:00:09  2016
def.txt   errorstatus2.txt  Sat        Nov  12  03:00:09  2016

ठंडा! धन्यवाद!! लेकिन इन मूल्यों को एक्सेल प्रारूप में कैसे प्रिंट करें। मैं एक्सेल शीट में कॉलम हेडर को
फाइलन

@ linux09 एक CSV बनाएं और एक्सेल के साथ आयात करें:echo Filename,Status,Timestamp; paste -d ',' - - - <file.txt
heemayl

प्रतिभाशाली! एक जादू की तरह काम करता है। बहुत बहुत शुक्रिया
linux09

6

आप awk का उपयोग कर सकते हैं:

awk 'NR % 3 {printf "%s ", $0; next}1'

आउटपुट बहुत सुंदर नहीं हो सकता है:

$ awk 'NR % 3 {printf "%s ", $0; next} 1' input
abc.txt errorstatus1 Fri Nov 11 02:00:09 2016
def.txt errorstatus2.txt Sat Nov 12 03:00:09 2016

आप %s\tटैब-अलग आउटपुट के बजाय उपयोग कर सकते हैं ।

  • NR % 3हर तीसरी पंक्ति के लिए शून्य (और असत्य) है, इसलिए दूसरी रेखाएं एक नई रेखा के बजाय उनके साथ एक स्थान के साथ मुद्रित होती हैं। nextबस अगले पुनरावृत्ति शुरू होता है।
  • हर तीसरी लाइन के रूप में मुद्रित किया जाता 1है, क्योंकि यह पहली ब्लॉक से मेल नहीं खाता है, क्योंकि इसके बाद एक नई लाइन के साथ है।

5

वहाँ भी है rs(BSD r e s hape उपयोगिता):

DESCRIPTION
     rs reads the standard input, interpreting each line as a row of blank-
     separated entries in an array, transforms the array according to the
     options, and writes it on the standard output.  With no arguments it
     transforms stream input into a columnar format convenient for terminal
     viewing.

विशेष रूप से,

     -e      Consider each line of input as an array entry.

इसलिए

$ rs -e < file
abc.txt                   errorstatus1              Fri Nov 11 02:00:09 2016
def.txt                   errorstatus2.txt          Sat Nov 12 03:00:09 2016

या (हेडर जोड़ने के लिए)

$ { printf '%s\n' Filename Status Timestamp ; cat file ; } | rs -e
Filename                  Status                    Timestamp
abc.txt                   errorstatus1              Fri Nov 11 02:00:09 2016
def.txt                   errorstatus2.txt          Sat Nov 12 03:00:09 2016

3

पूर्णता के लिए, आप ऐसा sedभी कर सकते हैं :

sed -e '1iFilename\tStatus\tTimestamp' -e 'N;N;y/\n/\t/' file.txt
  • 1iFilename\tStatus\tTimestamp शीर्ष लेख पंक्ति 1 से पहले सम्मिलित करता है
  • N;N पैटर्न बफर में दो और पंक्तियों को पढ़ता है, जिससे कुल 3 नईलाइन अलग-अलग लाइनें बनती हैं
  • y/\n/\t/ पैटर्न बफ़र में टैब के साथ सभी नई सूचियों को बदलता है

i, Nऔर ysed आदेशों यहाँ प्रलेखित रहे हैं


महान .. क्या आप संक्षेप में आपके द्वारा उपयोग किए जाने वाले भावों पर भी टिप्पणी कर सकते हैं? धन्यवाद!
कैम्पा

जी हाँ, एकदम सही दोस्त
कैम्पा

1

यह हमेशा संभव है कि AWK या पर्ल और निश्चित रूप से पायथन के साथ पाठ प्रसंस्करण के लिए कुछ पकाया जाए, जो कि यह उत्तर प्रदान करता है।

एक-लाइनर के रूप में:

python -c 'import sys;print "Filename\tStatus\tTimestamp"; lines=[l.strip() for l in sys.stdin];print "".join([l+"\n" if i%3 == 0 else l+"\t" for i,l in enumerate(lines,1) ])' < input.txt

मल्टी-लाइन स्क्रिप्ट के रूप में

import sys
print "Filename\tStatus\tTimestamp"
lines=[l.strip() for l in sys.stdin]
print "".join([l+"\n" if i%3 == 0 else l+"\t" for i,l in enumerate(lines,1) ])

मूल विचार यहाँ स्क्रिप्ट इनपुट को स्टड के माध्यम से देना है (शेल के पुनर्निर्देशन का उपयोग करके <, हालांकि एक पाइप का भी उपयोग किया जा सकता है)। स्क्रिप्ट फ़ील्ड को अलग करने के लिए टैब का उपयोग करती है, हालांकि रिक्त स्थान का उपयोग अधिक "ठीक-ट्यून" आउटपुट के लिए भी किया जा सकता है।

ओपी द्वारा प्रदान किए गए इनपुट उदाहरण का उपयोग करके नमूना आउटपुट:

$ python -c 'import sys;print "Filename\tStatus\tTimestamp";                                   
> lines=[l.strip() for l in sys.stdin];
> print "".join([l+"\n" if i%3 == 0 else l+"\t" for i,l in enumerate(lines,1) ])' < input.txt
Filename    Status  Timestamp
abc.txt errorstatus1    Fri Nov 11 02:00:09 2016
def.txt errorstatus2    Sat Nov 12 03:00:09 2016
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.