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,
In this completely revised second edition of the perennial best seller How Linux Works, author Brian Ward makes the concepts behind Linux internals accessible to anyone curious about the inner workings of the operating system. Inside, you'll find the kind of knowledge that normally comes from years of experience doing things the hard way.$ Check price
This foam seat cushion relieves lowerback pain, numbness and pressure sores by promoting healthy weight distribution, posture and spine alignment. Furthermore, it reduces pressure on the tailbone and hip bones while sitting. Perfect for sitting on the computer desk for long periods of time.$ Check price