मेरे पास एक फाइल है, foo.txt
, जिसमें निम्नलिखित पंक्तियाँ हैं:
a
b
c
मैं एक साधारण आदेश चाहता हूं जिसके परिणामस्वरूप सामग्री होती है foo.txt
:
a
b
मेरे पास एक फाइल है, foo.txt
, जिसमें निम्नलिखित पंक्तियाँ हैं:
a
b
c
मैं एक साधारण आदेश चाहता हूं जिसके परिणामस्वरूप सामग्री होती है foo.txt
:
a
b
जवाबों:
का उपयोग कर GNU sed
:
sed -i '$ d' foo.txt
-i
विकल्प में मौजूद नहीं है GNU sed
3.95 की तुलना में पुराने संस्करणों है, तो आप एक अस्थायी फ़ाइल के साथ एक फिल्टर के रूप में उपयोग करने के लिए है:
cp foo.txt foo.txt.tmp
sed '$ d' foo.txt.tmp > foo.txt
rm -f foo.txt.tmp
बेशक, उस मामले में आप के head -n -1
बजाय भी इस्तेमाल कर सकते हैंsed
।
मैक ओ एस:
Mac OS X पर (10.7.4 के रूप में), sed -i
ऊपर दिए गए कमांड के बराबर है
sed -i '' -e '$ d' foo.txt
$ d
रेगेक्स नहीं है। यह एक sed कमांड है। d
एक पंक्ति को हटाने का आदेश है, जबकि $
"फ़ाइल में अंतिम पंक्ति" है। जब किसी कमांड से पहले किसी स्थान (सीड लिंगो में "रेंज" कहा जाता है) को निर्दिष्ट किया जाता है, तो उस कमांड को केवल निर्दिष्ट स्थान पर लागू किया जाता है। तो, यह कमांड स्पष्ट रूप से कहता है "एक फ़ाइल में अंतिम पंक्ति की सीमा में, इसे हटाएं"। यदि आप मुझसे पूछें तो बहुत ही सुस्त और सीधे मुद्दे पर।
यह अब तक का सबसे तेज और सरल उपाय है, खासकर बड़ी फाइलों पर:
head -n -1 foo.txt > temp.txt ; mv temp.txt foo.txt
यदि आप शीर्ष पंक्ति को हटाना चाहते हैं तो इसका उपयोग करें:
tail -n +2 foo.txt
जिसका अर्थ है लाइन 2 पर शुरू होने वाली आउटपुट लाइनें।
sed
फ़ाइल के ऊपर या नीचे से लाइनें हटाने के लिए उपयोग न करें - यदि फ़ाइल बड़ी है तो यह बहुत धीमी है।
head -n -1 foo.txt
पर्याप्त है
brew install coreutils
(GNU कोर उपयोगिताओं) कर सकते हैं और ghead
इसके बजाय उपयोग कर सकते हैं head
।
FILE=$1; TAIL=$2; head -n -${TAIL} ${FILE} > temp ; mv temp ${FILE}
myFile से उदाहरण के लिए 4 लाइनों को हटाने के रूप में के लिए भागो यह: ./TAILfixer myfile 4
निश्चित रूप से पहले यह द्वारा निष्पादन योग्य बनानेchmod +x TAILfixer
sed
, इस आदेश के रूप में अच्छी तरह से बहुत धीमी गति से है
मुझे यहां सभी उत्तरों से परेशानी थी क्योंकि मैं एक बड़ी फ़ाइल (~ 300 जीबी) के साथ काम कर रहा था और कोई भी समाधान नहीं मिला। यहाँ मेरा समाधान है:
dd if=/dev/null of=<filename> bs=1 seek=$(echo $(stat --format=%s <filename> ) - $( tail -n1 <filename> | wc -c) | bc )
शब्दों में: उस फ़ाइल की लंबाई ज्ञात करें जिसे आप समाप्त करना चाहते हैं (इसकी अंतिम पंक्ति की लंबाई की फ़ाइल माइनस लंबाई, का उपयोग करके bc
), और, उस स्थिति को फ़ाइल के अंत में सेट करें ( dd
एक के बाइट द्वारा/dev/null
पर यह)।
यह तेजी से है क्योंकि tail
अंत से पढ़ना शुरू होता है, और जगह मेंdd
फ़ाइल को अधिलेखित कर देगा प्रत्येक पंक्ति को कॉपी (और पार्स) के बजाय , जो कि अन्य समाधान करते हैं।
नोट: यह जगह में फ़ाइल से लाइन हटाता है! अपनी फ़ाइल को आज़माने से पहले डमी फ़ाइल पर बैकअप या परीक्षण करें!
पूरी फ़ाइल को पढ़ने या किसी भी चीज़ को दोबारा लिखने के बिना किसी फ़ाइल से अंतिम पंक्ति को हटाने के लिए , आप उपयोग कर सकते हैं
tail -n 1 "$file" | wc -c | xargs -I {} truncate "$file" -s -{}
अंतिम पंक्ति को निकालने के लिए और इसे stdout पर प्रिंट करें ("पॉप" इट), आप उस कमांड को इसके साथ जोड़ सकते हैं tee
:
tail -n 1 "$file" | tee >(wc -c | xargs -I {} truncate "$file" -s -{})
ये कमांड कुशलता से एक बहुत बड़ी फाइल को प्रोसेस कर सकते हैं। यह योसी के उत्तर के समान है और इससे प्रेरित है, लेकिन यह कुछ अतिरिक्त कार्यों का उपयोग करने से बचता है।
यदि आप इन्हें बार-बार उपयोग करने जा रहे हैं और त्रुटि से निपटने और कुछ अन्य सुविधाएँ चाहते हैं, तो आप poptail
यहाँ कमांड का उपयोग कर सकते हैं:
https://github.com/donm/evenmoreutils
truncate
डिफ़ॉल्ट रूप से OS X पर उपलब्ध नहीं है। लेकिन ब्रू का उपयोग करके इंस्टॉल करना आसान है brew install truncate
:।
मैक उपयोगकर्ता
अगर आप केवल आखिरी लाइन हटाए गए आउटपुट को फाइल में बदले बिना चाहते हैं
sed -e '$ d' foo.txt
यदि आप इनपुट फ़ाइल की अंतिम पंक्ति को स्वयं हटाना चाहते हैं
sed -i '' -e '$ d' foo.txt
-i ''
फ़ाइल को इन-प्लेस में संशोधित करने के लिए sed को बताता है, जबकि एक फाइल में बैकअप को पैरामीटर के रूप में दिए गए एक्सटेंशन के साथ रखता है। चूंकि पैरामीटर एक खाली स्ट्रिंग है, इसलिए कोई बैकअप फ़ाइल नहीं बनाई गई है। -e
कमांड को निष्पादित करने के लिए sed को बताता है। कमांड का $ d
अर्थ है: अंतिम पंक्ति ( $
) ढूंढें और इसे हटाएं ( d
)।
मैक पर, हेड-एन -1 अभ्यस्त काम। और, मैं केवल "सिर" और / या "पूंछ" कमांड का उपयोग करके इस समस्या को हल करने के लिए एक सरल समाधान [प्रसंस्करण समय की चिंता किए बिना] खोजने की कोशिश कर रहा था।
मैंने आदेशों के निम्नलिखित अनुक्रम की कोशिश की और खुश था कि मैं इसे "पूंछ" कमांड का उपयोग करके हल कर सकता था [मैक पर उपलब्ध विकल्पों के साथ]। इसलिए, यदि आप मैक पर हैं, और इस समस्या को हल करने के लिए केवल "पूंछ" का उपयोग करना चाहते हैं, तो आप इस कमांड का उपयोग कर सकते हैं:
बिल्ली file.txt | पूंछ -r | tail -n +2 | पूँछ -r
1> टेल-आर: बस इसके इनपुट में लाइनों के क्रम को उलट देता है
2> टेल-एन +2: यह अपने इनपुट में दूसरी लाइन से शुरू होने वाली सभी लाइनों को प्रिंट करता है
ghead -n -1
awk 'NR>1{print buf}{buf = $0}'
अनिवार्य रूप से, यह कोड निम्नलिखित कहता है:
पहली के बाद की प्रत्येक पंक्ति के लिए, बफ़र की गई पंक्ति को प्रिंट करें
प्रत्येक पंक्ति के लिए, बफर रीसेट करें
बफ़र एक पंक्ति से पिछड़ा हुआ है, इसलिए आप मुद्रण लाइनों को 1 से n-1 तक समाप्त करते हैं
awk "NR != `wc -l < text.file`" text.file |> text.file
यह स्निपेट टोटका करता है।
ये दोनों समाधान अन्य रूपों में यहां हैं। मुझे ये कुछ अधिक व्यावहारिक, स्पष्ट और उपयोगी लगे:
Dd का उपयोग करना:
BADLINESCOUNT=1
ORIGINALFILE=/tmp/whatever
dd if=${ORIGINALFILE} of=${ORIGINALFILE}.tmp status=none bs=1 count=$(printf "$(stat --format=%s ${ORIGINALFILE}) - $(tail -n${BADLINESCOUNT} ${ORIGINALFILE} | wc -c)\n" | bc )
/bin/mv -f ${ORIGINALFILE}.tmp ${ORIGINALFILE}
ट्रंकट का उपयोग करना:
BADLINESCOUNT=1
ORIGINALFILE=/tmp/whatever
truncate -s $(printf "$(stat --format=%s ${ORIGINALFILE}) - $(tail -n${BADLINESCOUNT} ${ORIGINALFILE} | wc -c)\n" | bc ) ${ORIGINALFILE}
sed '$d' ~/path/to/your/file/name
sed -i '' -e '$ d' ~/path/to/your/file/name
यहां बताया गया है कि आप इसे मैन्युअल रूप से कैसे कर सकते हैं (मैं व्यक्तिगत रूप से इस पद्धति का बहुत उपयोग करता हूं जब मुझे फ़ाइल में अंतिम पंक्ति को जल्दी से हटाने की आवश्यकता होती है):
vim + [FILE]
+
वहाँ उस संकेत का मतलब है कि जब फ़ाइल विम पाठ संपादक में खोली जाती है, तो कर्सर फ़ाइल की अंतिम पंक्ति पर स्थित होगा।
अब बस d
अपने कीबोर्ड पर दो बार दबाएं । यह वही करेगा जो आप चाहते हैं - अंतिम पंक्ति को हटा दें। उसके बाद, प्रेस :
द्वारा पीछा किया x
और फिर प्रेस Enter
। यह परिवर्तनों को बचाएगा और आपको शेल में वापस लाएगा। अब, अंतिम पंक्ति को सफलतापूर्वक हटा दिया गया है।
sed -i
ऊपर दिए गए कमांड के बराबर हैsed -i '' -e '$ d' foo.txt
। इसके अलावा,head -n -1
वर्तमान में एक मैक पर काम नहीं करेगा।