Задача проста. Вам нужно удалить определенные строки из текстового файла в терминале Linux.
Вы можете использовать текстовый редактор типа Vim или Nano, войти в файл и удалить нужные строки.
Сейчас мы рассмотрим продолжение нашей прошлой статьи:
😡 Как удалить строки, соответствующие определенному шаблону в файле, используя SED
Однако такой подход не подходит для автоматизации с помощью скриптов bash.
Вместо этого можно воспользоваться мощным редактором командной строки sed и удалить строки, соответствующие определенным критериям.
И, конечно же, вы можете использовать sed в своих скриптах shell.
Позвольте мне показать несколько примеров использования.
- 🐧 Как заменить переменную в файле с помощью sed?
- 🐧 Как раскомментировать строки в файле с помощью SED на Linux
Приведенные здесь примеры мгновенно изменяют исходный файл.
Прежде чем приступать к экспериментам с файлом, неплохо было бы сделать его резервную копию.
Удаление n-ой строки из файла
Представьте, что вам нужно удалить 7ую строку в файле.
Вы можете использовать команду sed следующим образом
sed -i '7d' filename
Позвольте мне объяснить, как это работает:
- -i: Эта опция включает редактирование на месте. По умолчанию sed отображает только вывод. С опцией -i он изменяет фактический файл, не отображая его на дисплее.
- 7d: Здесь 7 – это номер строки, а d указывает на удаление строки.
- filename: Это файл, который вы хотите изменить. Вы также можете указать абсолютный или относительный путь, если файл находится в другом каталоге.
Позвольте мне показать на реальном примере.
Вот пример текстового файла с именем agatha.txt:
The Mystery of the Blue Train
The Seven Dials Mystery
The Murder at the Vicarage
Giant's Bread
The Floating Admiral
The Sittaford Mystery
Peril at End House
Lord Edgware Dies
Чтобы удалить 4-ю строку из этого файла, я использую:
sed '4d' agatha.txt
Это приведет к следующему отображению с удаленной строкой “Giant’s Bread”:
The Mystery of the Blue Train
The Seven Dials Mystery
The Murder at the Vicarage
The Floating Admiral
The Sittaford Mystery
Peril at End House
Lord Edgware Dies
Теперь, допустим, вы хотите удалить первую строку файла в командной строке Linux.
Используйте sed следующим образом:
sed -i '1d' filename
Удаление последней строки с помощью sed
Вы научились удалять определенную строку, но что если вам нужно удалить последнюю строку?
Вы всегда можете получить общее количество строк в файле с помощью команды wc и использовать это число в sed.
Однако sed имеет специальный способ удаления последней строки файла.
Теперь вам больше не нужно беспокоиться о количестве строк.
sed -i '$d' filename.txt
Удаление диапазона строк
Аналогично тому, что вы видели ранее, вы также можете удалить диапазон строк из файла.
Предположим, вам нужно удалить строки с 11 по 15, вы можете указать диапазон следующим образом:
sed -i '11,15d' filename
Обратите внимание, что при этом будут удалены строки 11 и 15, а не только те, которые находятся между ними.
Удаление строк, содержащих шаблон
Вы также можете использовать sed для удаления всех строк, которые содержат заданную строку или соответствуют определенному шаблону.
Команда, показанная ниже удалит все строки, содержащие слово ‘string’:
sed -i '/string/d' filename
Обратите внимание, что поиск осуществляется с учетом регистра.
Вы также можете использовать regex-шаблон вместо обычной строки.
Удаление строк, начинающихся со слова
Если вы хотите удалить все строки, начинающиеся с определенного слова или буквы, вам просто нужно указать шаблон regex следующим образом:
sed -i '/^word/d' filename
Бонусный совет: Удаление всех пустых строк
Прежде чем закончить эту статью, позвольте мне быстро рассказать, как вы можете удалить все пустые строки с помощью sed:
sed -i '/^$/d' filename
Надеюсь, этот быстрый совет поможет вам удалить строки из текстового файла в командной строке Linux.