To delete lines from our file, we use the
d command instead of the
p command as we saw earlier.
Notice that for deleting, we no longer need the
-n option since
sed won't print out the deleted lines (once they are deleted there is nothing to be printed). Thus the output will only be the lines that were not deleted.
Make sure to specify an address! Without one, sed will delete all lines, which isn't you wouldn't want.
Let's see what happens when we delete the third and fourth lines:
$ sed '3,4d' oneOS.txt
One OS to rule them all, One OS to find them. In the bright land of Linux, Where the hackers play.
Notice that using the delete operation does not save the output to a new file. To save to a new file, simply direct the output to a new file with the redirection symbol (
$ sed '1~2d' BSD > everyOther.txt
To edit the file and save directly, we can use the
-i option. Note that you may lose data if used incorrectly, so be sure to create a backup prior to editing! To create a .bak file directly within the command, tack on the
.bak (or any other extension) after the
$ sed -i.bak 'd' oneOS.txt # Woops! Accidentally deleted all lines, but good thing we made a backup!
The "-i" in-place option varies between implementations of sed. GNU sed allows for it while FreeBSD's sed requires an extension parameter. OpenBSD's sed does not support the "-i" option at all.
To delete lines that contain a specific match to a regex, embed the regular expression between two slashes, before the option.
This command would delete the lines that start with an uppercase vowel.
$ sed '/^[AEIOU]/d' oneOS.txt
Where the hackers play.
Here are a list of more fun deletions that you may find helpful:
To specify multiple delete commands, separate them with a semi-colon (
$ sed '1d;$d' oneOS.txt # Deletes first and last line
One OS to find them. One OS to call them all, And in salvation bind them. In the bright land of Linux,
To delete every other line, refer back to the
~ address operator, which takes every multiple starting from an integer. Note that the
~ syntax is only GNU-specific and won't work in BSD flavors of sed.
$ sed '1~2d' oneOS.txt # Removes all odd number lines (only on GNU)
One OS to rule them all, One OS to call them all, In the bright land of Linux,
Use a simple regular expression to rid of all empty lines. Or rid the inverse of all lines that have content.
$ sed '/^$/d' oneOS.txt $ sed '/./!d' oneOS.txt
$ sed '/salvation/,$d' oneOS.txt
One OS to rule them all, One OS to find them. One OS to call them all,
Linux for Beginners doesn't make any assumptions about your background or knowledge of Linux. You need no prior knowledge to benefit from this book. You will be guided step by step using a logical and systematic approach. As new concepts, commands, or jargon are encountered they are explained in plain language, making it easy for anyone to understand.$ Check price
Ever feel achy from sitting crunched up on your computer table? Try lying down with these optical glasses that allow you to work on your laptop while lying flat on your back. This is the perfect solution with those with limited mobility or those who wish to prevent neck cramps and back strains.$ Check price