Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
menu search
person
Welcome To Ask or Share your Answers For Others

Categories

I have the following lines in a text file 'file.txt'

String1 ABCDEFGHIJKL
String2 DCEGIJKLQMAB

I want to print the characters corresponding to 'String1' in another text file 'text.txt' like this

ABCDEFGHIJKL

Here, I don't want to use any line numbers. Any suggestions using 'sed' command?. I tried with between 'string 1' and 'string 2', but couldn't obtain command excluding 'string1'. This following code for excluding only 'string2'.

sed -n '/^string1/,/^string2/{p;/^string2/q}' file.txt | sed '$d' > text.txt

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
1.6k views
Welcome To Ask or Share your Answers For Others

1 Answer

Use GNU grep:

grep -Po 'String1s+K.*' in_file

Here, grep uses the following options:
-P : Use Perl regexes.
-o : Print the matches only (1 match per line), not the entire lines.

K : Cause the regex engine to "keep" everything it had matched prior to the K and not include it in the match. Specifically, ignore the preceding part of the regex when printing the match.

SEE ALSO:
grep manual
perlre - Perl regular expressions


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
thumb_up_alt 0 like thumb_down_alt 0 dislike
Welcome to ShenZhenJia Knowledge Sharing Community for programmer and developer-Open, Learning and Share
...