How to copy the rest of lines of a file to another fileHow to print all lines after a match up to the end of...
Why do we say 'Pairwise Disjoint', rather than 'Disjoint'?
Create chunks from an array
When an outsider describes family relationships, which point of view are they using?
Does the US political system, in principle, allow for a no-party system?
How can I wire a Raspberry Pi to an 8-relay board in a tidy professional manner?
How can a demon take control of a human body during REM sleep?
What does *dead* mean in *What do you mean, dead?*?
Finding the minimum value of a function without using Calculus
If sound is a longitudinal wave, why can we hear it if our ears aren't aligned with the propagation direction?
Are all players supposed to be able to see each others' character sheets?
-1 to the power of a irrational number
Use Mercury as quenching liquid for swords?
Is there stress on two letters on the word стоят
ESPP--any reason not to go all in?
Is divide-by-zero a security vulnerability?
How to educate team mate to take screenshots for bugs with out unwanted stuff
Is it a Cyclops number? "Nobody" knows!
Can I negotiate a patent idea for a raise, under French law?
How can I portion out frozen cookie dough?
How do you make a gun that shoots melee weapons and/or swords?
Can one live in the U.S. and not use a credit card?
Does an unused member variable take up memory?
What is Tony Stark injecting into himself in Iron Man 3?
Boss Telling direct supervisor I snitched
How to copy the rest of lines of a file to another file
How to print all lines after a match up to the end of the file?compare two files get identical list“Ungrep” - which patterns aren't matchedOutputting common lines from 2 files and uncommon lines from both the files in one output fileReplace lines matching a pattern with lines from another file in orderCompare two files and print only the first word of the lines which don't match along with a stringgnuwin bash If .txt file contains string copy filecopy files and append in another directory?How do I create a new txt file from another file which is a list?counting the matched linesHow to grep the rows with same column in different files and print specific column and add onto the original file?
I have the string xyz which is a line in file1.txt, I want to copy all the lines after xyz in file1.txt to a new file file2.txt. How can I achieve this?
I know about cat command. But how to specify the starting line?
files grep cat file-copy file-transfer
add a comment |
I have the string xyz which is a line in file1.txt, I want to copy all the lines after xyz in file1.txt to a new file file2.txt. How can I achieve this?
I know about cat command. But how to specify the starting line?
files grep cat file-copy file-transfer
2
Do you want to include thatxyzline or exclude it from being copied ? Also, what happens if you have multiple lines matchingxyz?
– don_crissti
1 hour ago
2
Possible duplicate of How to print all lines after a match up to the end of the file?
– Kusalananda
1 hour ago
add a comment |
I have the string xyz which is a line in file1.txt, I want to copy all the lines after xyz in file1.txt to a new file file2.txt. How can I achieve this?
I know about cat command. But how to specify the starting line?
files grep cat file-copy file-transfer
I have the string xyz which is a line in file1.txt, I want to copy all the lines after xyz in file1.txt to a new file file2.txt. How can I achieve this?
I know about cat command. But how to specify the starting line?
files grep cat file-copy file-transfer
files grep cat file-copy file-transfer
asked 1 hour ago
user9371654user9371654
30117
30117
2
Do you want to include thatxyzline or exclude it from being copied ? Also, what happens if you have multiple lines matchingxyz?
– don_crissti
1 hour ago
2
Possible duplicate of How to print all lines after a match up to the end of the file?
– Kusalananda
1 hour ago
add a comment |
2
Do you want to include thatxyzline or exclude it from being copied ? Also, what happens if you have multiple lines matchingxyz?
– don_crissti
1 hour ago
2
Possible duplicate of How to print all lines after a match up to the end of the file?
– Kusalananda
1 hour ago
2
2
Do you want to include that
xyz line or exclude it from being copied ? Also, what happens if you have multiple lines matching xyz ?– don_crissti
1 hour ago
Do you want to include that
xyz line or exclude it from being copied ? Also, what happens if you have multiple lines matching xyz ?– don_crissti
1 hour ago
2
2
Possible duplicate of How to print all lines after a match up to the end of the file?
– Kusalananda
1 hour ago
Possible duplicate of How to print all lines after a match up to the end of the file?
– Kusalananda
1 hour ago
add a comment |
4 Answers
4
active
oldest
votes
Using GNU sed
To copy all lines after xyz, try:
sed '0,/xyz/d' file1.txt >file2.txt
1,/xyz/ specifies a range of lines starting with the first and ending with the first occurrence of a line matching xyz. d tells sed to delete those lines.
Note: For BSD/MacOS sed, one can use sed '1,/xyz/d' file1.txt >file2.txt but this only works if the first appearance of xyz is in the second line or later. (Hat tip: kusalananda.)
Example
Consider this test file:
$ cat file1.txt
a
b
xyz
c
d
Run our command:
$ sed '1,/xyz/d' file1.txt >file2.txt
$ cat file2.txt
c
d
Using awk
The same logic can used with awk:
awk 'NR==1,/xyz/{next} 1' file1.txt >file2.txt
NR==1,/xyz/{next} tells awk to skip over all lines from the first (NR==1) to the first line matching the regex xyz. 1 tells awk to print any remaining lines.
@Kusalananda Thanks. Answer updated to include a GNU sed solution instead.
– John1024
55 mins ago
The proper way to do this (portably) withsedis shown in mikeserv's answer to the duplicate Q.
– don_crissti
52 mins ago
@don_crissti Are you referring to this answer? If so, it does not work for me. This is because sed, as currently written, like many other utilities, does not read in a line at a time; it reads in a buffer-full at a time.
– John1024
38 mins ago
@John1024 Whatsedare you using there?
– Kusalananda
32 secs ago
add a comment |
With ed:
ed -s file.txt <<< $'/xyz/+1,$w file2.txt'
This sends one (ranged) command to ed: from the line after (+1) the one containing xyz until the end of the file ($), write those lines to file2.txt.
add a comment |
$ sed -n '/xyz/,$p' file.txt > file2.txt
With -n we prevent sed to print every line. With $ means end of file end p stands for print line. So /xyz/$p means: If a line matches xyz print it until the end of the file.
This would also print the line matchingxyz, not from the line after.
– Kusalananda
1 hour ago
add a comment |
There is also csplit :
csplit -s file1.txt %xyz%1
add a comment |
Your Answer
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "106"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f505388%2fhow-to-copy-the-rest-of-lines-of-a-file-to-another-file%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
Using GNU sed
To copy all lines after xyz, try:
sed '0,/xyz/d' file1.txt >file2.txt
1,/xyz/ specifies a range of lines starting with the first and ending with the first occurrence of a line matching xyz. d tells sed to delete those lines.
Note: For BSD/MacOS sed, one can use sed '1,/xyz/d' file1.txt >file2.txt but this only works if the first appearance of xyz is in the second line or later. (Hat tip: kusalananda.)
Example
Consider this test file:
$ cat file1.txt
a
b
xyz
c
d
Run our command:
$ sed '1,/xyz/d' file1.txt >file2.txt
$ cat file2.txt
c
d
Using awk
The same logic can used with awk:
awk 'NR==1,/xyz/{next} 1' file1.txt >file2.txt
NR==1,/xyz/{next} tells awk to skip over all lines from the first (NR==1) to the first line matching the regex xyz. 1 tells awk to print any remaining lines.
@Kusalananda Thanks. Answer updated to include a GNU sed solution instead.
– John1024
55 mins ago
The proper way to do this (portably) withsedis shown in mikeserv's answer to the duplicate Q.
– don_crissti
52 mins ago
@don_crissti Are you referring to this answer? If so, it does not work for me. This is because sed, as currently written, like many other utilities, does not read in a line at a time; it reads in a buffer-full at a time.
– John1024
38 mins ago
@John1024 Whatsedare you using there?
– Kusalananda
32 secs ago
add a comment |
Using GNU sed
To copy all lines after xyz, try:
sed '0,/xyz/d' file1.txt >file2.txt
1,/xyz/ specifies a range of lines starting with the first and ending with the first occurrence of a line matching xyz. d tells sed to delete those lines.
Note: For BSD/MacOS sed, one can use sed '1,/xyz/d' file1.txt >file2.txt but this only works if the first appearance of xyz is in the second line or later. (Hat tip: kusalananda.)
Example
Consider this test file:
$ cat file1.txt
a
b
xyz
c
d
Run our command:
$ sed '1,/xyz/d' file1.txt >file2.txt
$ cat file2.txt
c
d
Using awk
The same logic can used with awk:
awk 'NR==1,/xyz/{next} 1' file1.txt >file2.txt
NR==1,/xyz/{next} tells awk to skip over all lines from the first (NR==1) to the first line matching the regex xyz. 1 tells awk to print any remaining lines.
@Kusalananda Thanks. Answer updated to include a GNU sed solution instead.
– John1024
55 mins ago
The proper way to do this (portably) withsedis shown in mikeserv's answer to the duplicate Q.
– don_crissti
52 mins ago
@don_crissti Are you referring to this answer? If so, it does not work for me. This is because sed, as currently written, like many other utilities, does not read in a line at a time; it reads in a buffer-full at a time.
– John1024
38 mins ago
@John1024 Whatsedare you using there?
– Kusalananda
32 secs ago
add a comment |
Using GNU sed
To copy all lines after xyz, try:
sed '0,/xyz/d' file1.txt >file2.txt
1,/xyz/ specifies a range of lines starting with the first and ending with the first occurrence of a line matching xyz. d tells sed to delete those lines.
Note: For BSD/MacOS sed, one can use sed '1,/xyz/d' file1.txt >file2.txt but this only works if the first appearance of xyz is in the second line or later. (Hat tip: kusalananda.)
Example
Consider this test file:
$ cat file1.txt
a
b
xyz
c
d
Run our command:
$ sed '1,/xyz/d' file1.txt >file2.txt
$ cat file2.txt
c
d
Using awk
The same logic can used with awk:
awk 'NR==1,/xyz/{next} 1' file1.txt >file2.txt
NR==1,/xyz/{next} tells awk to skip over all lines from the first (NR==1) to the first line matching the regex xyz. 1 tells awk to print any remaining lines.
Using GNU sed
To copy all lines after xyz, try:
sed '0,/xyz/d' file1.txt >file2.txt
1,/xyz/ specifies a range of lines starting with the first and ending with the first occurrence of a line matching xyz. d tells sed to delete those lines.
Note: For BSD/MacOS sed, one can use sed '1,/xyz/d' file1.txt >file2.txt but this only works if the first appearance of xyz is in the second line or later. (Hat tip: kusalananda.)
Example
Consider this test file:
$ cat file1.txt
a
b
xyz
c
d
Run our command:
$ sed '1,/xyz/d' file1.txt >file2.txt
$ cat file2.txt
c
d
Using awk
The same logic can used with awk:
awk 'NR==1,/xyz/{next} 1' file1.txt >file2.txt
NR==1,/xyz/{next} tells awk to skip over all lines from the first (NR==1) to the first line matching the regex xyz. 1 tells awk to print any remaining lines.
edited 55 mins ago
answered 1 hour ago
John1024John1024
47.5k5110125
47.5k5110125
@Kusalananda Thanks. Answer updated to include a GNU sed solution instead.
– John1024
55 mins ago
The proper way to do this (portably) withsedis shown in mikeserv's answer to the duplicate Q.
– don_crissti
52 mins ago
@don_crissti Are you referring to this answer? If so, it does not work for me. This is because sed, as currently written, like many other utilities, does not read in a line at a time; it reads in a buffer-full at a time.
– John1024
38 mins ago
@John1024 Whatsedare you using there?
– Kusalananda
32 secs ago
add a comment |
@Kusalananda Thanks. Answer updated to include a GNU sed solution instead.
– John1024
55 mins ago
The proper way to do this (portably) withsedis shown in mikeserv's answer to the duplicate Q.
– don_crissti
52 mins ago
@don_crissti Are you referring to this answer? If so, it does not work for me. This is because sed, as currently written, like many other utilities, does not read in a line at a time; it reads in a buffer-full at a time.
– John1024
38 mins ago
@John1024 Whatsedare you using there?
– Kusalananda
32 secs ago
@Kusalananda Thanks. Answer updated to include a GNU sed solution instead.
– John1024
55 mins ago
@Kusalananda Thanks. Answer updated to include a GNU sed solution instead.
– John1024
55 mins ago
The proper way to do this (portably) with
sed is shown in mikeserv's answer to the duplicate Q.– don_crissti
52 mins ago
The proper way to do this (portably) with
sed is shown in mikeserv's answer to the duplicate Q.– don_crissti
52 mins ago
@don_crissti Are you referring to this answer? If so, it does not work for me. This is because sed, as currently written, like many other utilities, does not read in a line at a time; it reads in a buffer-full at a time.
– John1024
38 mins ago
@don_crissti Are you referring to this answer? If so, it does not work for me. This is because sed, as currently written, like many other utilities, does not read in a line at a time; it reads in a buffer-full at a time.
– John1024
38 mins ago
@John1024 What
sed are you using there?– Kusalananda
32 secs ago
@John1024 What
sed are you using there?– Kusalananda
32 secs ago
add a comment |
With ed:
ed -s file.txt <<< $'/xyz/+1,$w file2.txt'
This sends one (ranged) command to ed: from the line after (+1) the one containing xyz until the end of the file ($), write those lines to file2.txt.
add a comment |
With ed:
ed -s file.txt <<< $'/xyz/+1,$w file2.txt'
This sends one (ranged) command to ed: from the line after (+1) the one containing xyz until the end of the file ($), write those lines to file2.txt.
add a comment |
With ed:
ed -s file.txt <<< $'/xyz/+1,$w file2.txt'
This sends one (ranged) command to ed: from the line after (+1) the one containing xyz until the end of the file ($), write those lines to file2.txt.
With ed:
ed -s file.txt <<< $'/xyz/+1,$w file2.txt'
This sends one (ranged) command to ed: from the line after (+1) the one containing xyz until the end of the file ($), write those lines to file2.txt.
answered 25 mins ago
Jeff SchallerJeff Schaller
43.2k1159138
43.2k1159138
add a comment |
add a comment |
$ sed -n '/xyz/,$p' file.txt > file2.txt
With -n we prevent sed to print every line. With $ means end of file end p stands for print line. So /xyz/$p means: If a line matches xyz print it until the end of the file.
This would also print the line matchingxyz, not from the line after.
– Kusalananda
1 hour ago
add a comment |
$ sed -n '/xyz/,$p' file.txt > file2.txt
With -n we prevent sed to print every line. With $ means end of file end p stands for print line. So /xyz/$p means: If a line matches xyz print it until the end of the file.
This would also print the line matchingxyz, not from the line after.
– Kusalananda
1 hour ago
add a comment |
$ sed -n '/xyz/,$p' file.txt > file2.txt
With -n we prevent sed to print every line. With $ means end of file end p stands for print line. So /xyz/$p means: If a line matches xyz print it until the end of the file.
$ sed -n '/xyz/,$p' file.txt > file2.txt
With -n we prevent sed to print every line. With $ means end of file end p stands for print line. So /xyz/$p means: If a line matches xyz print it until the end of the file.
answered 1 hour ago
finswimmerfinswimmer
72917
72917
This would also print the line matchingxyz, not from the line after.
– Kusalananda
1 hour ago
add a comment |
This would also print the line matchingxyz, not from the line after.
– Kusalananda
1 hour ago
This would also print the line matching
xyz, not from the line after.– Kusalananda
1 hour ago
This would also print the line matching
xyz, not from the line after.– Kusalananda
1 hour ago
add a comment |
There is also csplit :
csplit -s file1.txt %xyz%1
add a comment |
There is also csplit :
csplit -s file1.txt %xyz%1
add a comment |
There is also csplit :
csplit -s file1.txt %xyz%1
There is also csplit :
csplit -s file1.txt %xyz%1
answered 35 mins ago
ctac_ctac_
1,4221210
1,4221210
add a comment |
add a comment |
Thanks for contributing an answer to Unix & Linux Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f505388%2fhow-to-copy-the-rest-of-lines-of-a-file-to-another-file%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
2
Do you want to include that
xyzline or exclude it from being copied ? Also, what happens if you have multiple lines matchingxyz?– don_crissti
1 hour ago
2
Possible duplicate of How to print all lines after a match up to the end of the file?
– Kusalananda
1 hour ago