Linux вывести файл начиная со строки

Содержание
  1. Как в Linux вывести строку?
  2. Как вывести сходу информацию из двух созданных файлов?
  3. Как вывести некоторую строку файла в Linux?
  4. Как вывести 5-ый строку в Linux?
  5. Как вывести нужные строки в Linux из файла с помощью sed?
  6. Вывод строк с определённого места
  7. 20 примеров использования потокового текстового редактора sed
  8. 1. Отобразить часть файла
  9. 2. Отобразить все кроме указанных строк.
  10. 3. Вывод каждой N строки начиная M строки .
  11. 4. Удаление строки из файла используя sed.
  12. 5. Удаление диапазона строк.
  13. 6. Удаление всех строк кроме указанных.
  14. 7. Вставка пустой строки/пробелов.
  15. 8. Поиск и замена строки.
  16. 9. Поиск и замена ВСЕХ найденных в файле слов.
  17. 10. Заменить n-ое вхождение шаблона строки.
  18. 11. Заменить текст на определенной строке.
  19. 12. Добавить строку до/после совпадения с заданным поиском.
  20. 13.Замена всей строки при совпадении поиска.
  21. Продвинутые опции sed
  22. 14. Запуск нескольких команд sed.
  23. 15. Создание резервной копии перед изменением файла.
  24. 16. Удаление текста начиная с указанного слова и заканчивая другим словом.
  25. 17. Добавление строк.
  26. 18. Удаление всех комментариев и пустых строк.
  27. 19. Получение списка пользователей из файла /etc/passwd.
  28. 20. Запрет перезаписи системных ссылок с помощью команды sed.

Как в Linux вывести строку?

Начнем с команды, с которой уже не однократно встречались, команда cat. Сначала посмотрим справку по данной команде с помощью man cat. Этая команда предназначена для объединения файлов и печати на стандартный вывод информации. Под стандартным выводом предполагается вывод на консоль информации. Так же можно увидеть, что у данной команды есть ключи.

Как вывести сходу информацию из двух созданных файлов?

А в справке было написано, что команда сможет объединять содержимое файлов.

cat hello1.txt hello2.txt > hello3.txt
cat hello3.txt

Мы вывели на стандартный вывод (консоль) содержание файлов и передали то, что на экране в новый файл hello3.txt. А затем просто вывели на консоль.

Как вывести некоторую строку файла в Linux?

При трейсе ошибки установки одного скрипта, возникла необходимость прочитать 98 строку файла. Делается это, ожидаемо, через команду вывода cat

# cat filename | head -n98 | tail -n1

где head -n предлагает сделать нужную строку, а tail -n задает сколько строк показать перед нужной. В данном варианте показана будет только одна строка.

То есть если нам необходимо вывести какой-никакой то сегмент строк, скажем, строки с 10 по 20, то выражение будет иметь вид

# cat filename | head -n20 | tail -n11

Как вывести 5-ый строку в Linux?

Если я хочу извлечь пятую строку файла, то делаю так:
$ head -n 5 имя_файла | tail -n 1

#!/bin/bash
for i in $(find /etc/ -type f);
do cat $i | head -n5 | tail -n1 >> ~/000
done
sort ~/000

Данный скрипт на bash хватит всё файлы из папки etc, с них берёт пятую строку и выводит в файл, который создаёт в домашнем каталоге, а затем сортирует.

Как вывести нужные строки в Linux из файла с помощью sed?

Тому, кто пишет много скриптов bash, довольно частенько приходится выбирать нужные строки из текста, например готовые блоки кода. Вчера я как раз обязан был извлечь первую строку из файла, назовем его somefile.txt.

Читайте также:  Star wars republic commando linux

$ cat somefile.txt
Line 1
Line 2
Line 3
Line 4

Это весьма просто сделать при помощи команды head:

$ head -1 somefile.txt
Line 1

Для более сложных задачек, например, извлечь вторую и третью строки из того же файла, команда head не подходит. Подавайте попробуем команду sed ? редактор потока (STream Editor). Моя первая попытка применить команду p (print) очутилась неудачной:

$ sed 1p somefile.txt
Line 1
Line 1
Line 2
Line 3
Line 4

Обратите внимание, что редактор отпечатывает весь файл, причем указанную первую строку печатает дважды. Почему? По умолчанию редактор перепечатывает на типовой вывод каждую строку вводимого файла. Четко заданная команда 1p приказывает печатать первоначальную строку. В итоге первая строка дублируется. Чтобы этого не происходило нужно подавить дефолтный вывод при поддержки опции -n, чтобы на выводе был только результат команды 1p:

$ sed -n 1p somefile.txt
Line 1

Можно пойти иным путем и удалить из файла все строки, кроме первой:

$ sed ‘1!d’ somefile.txt
Line 1

где ‘1!d’ значит: если строка не является первой (!), то подлежит удалению. Обратите внимания на кавычки (одинарные). Они асбсолютно необходимы, так как без них конструкция 1!d вызовет последнюю запускавшуюся в шелле команду, начинающуюся с буквы d. Для извлечения многих строк, скажем, со второй по четвертую, можно поступить одним из следующих способов:

$ sed -n 2,4p somefile.txt
$ sed ‘2,4!d’ somefile.txt

Перерыв обозначается через запятую включительно. А если строки не идут друг за другом, например, с первоначальной по вторую и еще четвертую?

$ sed -n -e 1,2p -e 4p somefile.txt

Источник

Вывод строк с определённого места

Как вывести строки, начиная со строки, содержащей определённое регулярное выражение, далее все строки под ней до конца файла?
У grep есть ключ -A, но ему надо указывать количество строк после совпадения. Надо получать вывод до конца файла.

Deleted ( 12.01.15 22:56:16 MSK )
Последнее исправление: Deleted 12.01.15 22:57:38 MSK (всего исправлений: 1)

Как вывести строки, начиная со строки, содержащей определённое регулярное выражение, далее все строки под ней до конца файла?

Собственно, примерно то же, что и у тебя. «64» — строка, с которой выводить. Регулярка, в общем.

Регулярное выражение для пустой подстроки (именно подстроки, а не строки ^$ ). Так как любая строка содержит в себе пустую подстроку, то оно матчит всё что угодно.

Регулярное выражение для пустой подстроки (именно подстроки, а не строки ^$). Так как любая строка содержит в себе пустую подстроку, то оно матчит всё что угодно.

я в курсе. Но // является _вторым_ адресным выражением, т.е. ДО чего искать. Если // матчит всё, что угодно, то должно получится вот так:

$ seq 1 100 | sed -n '/90/,/.*/p' 90 91 
$ echo "1 2 3 4 5 2 6 7 8"|sed -n '/2/,//p' 2 3 4 5 2 

Видимо в данном случае матчится уже скомпилированое регулярное выражение

Да, всё так. Я ещё думал (плохо думал раз упустил, что это конец диапазона): обычно ведь пустой RE не используется (ничего не матчит), либо используется для неявного переиспользования предыдущего шаблона (как в Vim).

@[~]$ seq 1 100 | sed -n '//p' sed: -e expression #1, char 0: no previous regular expression 

используется для неявного переиспользования предыдущего шаблона (как в Vim).

Буду знать. Раньше использовал подобную конструкцию именно в том варианте, как было задано в топике.

Читайте также:  Kaspersky удаленная установка агента linux

Источник

20 примеров использования потокового текстового редактора sed

Компьютерное

Команда sed (потоковый редактор) это очень мощная утилита работающая в Linux/Unix системах. В основном он используется для поиска и замены текста , но так же может применяться и для других манипуляций, таких как вставка, удаление, поиск и т.п. С sed, вы можете отредактировать файл не выполняя полного его открытия. В sed так же поддерживаются регулярные выражения, которые превращают sed в мощное средство манипуляцией текста.

В этой статье приведу несколько примеров использования SED. Основной синтаксис использования sed:

sed ОПЦИИ… [СКРИПТ] [ВХОДНОЙ ФАЙЛ…]

Картинка 11. Отобразить часть файла

С помощью sed мы можем просмотреть не весь файл, а только его часть. Посмотреть нужные строки можно так:

Опция n указывает что требуется вывести часть файла, а опция p, что требуется вывести только строки с 22 по 29.

2. Отобразить все кроме указанных строк.

Опция d указывает что надо удалить из вывода строки с 22 по 29.

3. Вывод каждой N строки начиная M строки .

Теперь, например выведем каждую 3-ю строку начиная со строки 2-ой.

4. Удаление строки из файла используя sed.

Где N это номер строки а опция d указывает что надо удалить эту строку. Чтобы удалить самую последнюю строку в файле выполните команду:

5. Удаление диапазона строк.

Данная команда удалит строки с 29 по 34 из файла testfile.txt

6. Удаление всех строк кроме указанных.

Чтобы удалить все строки в файле, кроме нужных используйте «!»

Здесь опция «!» означает отрицание, то есть меняет значение на противоположное. Получается что мы НЕ удаляем указанные строки. Поэтому все линии кроме 29-34 будут удалены из файла testfile.txt.

7. Вставка пустой строки/пробелов.

Для добавления пустой строки после каждой НЕ пустой строки используем опцию «G»

8. Поиск и замена строки.

Для поиска и замены найденной строки в файле:

sed 's/danger/safety/' testfile.txt

В этом примере мы ищем слово danger и сразу меняем его на слово safety в каждой строке, но только в первом найденном вхождении.

9. Поиск и замена ВСЕХ найденных в файле слов.

Для замены слова полностью во всём файле используем опции «g» в комбинации с «s»

sed 's/danger/safety/g' testfile.txt

10. Заменить n-ое вхождение шаблона строки.

Мы также можем заменить строку при n-ом найденном. Например заменим «danger» на «safety» только на второе появление в поиске:

sed 's/danger/safety/2' testfile.txt

Для замены «danger» на «safety» во втором найденном результате в КАЖДОЙ строке файла:

sed 's/danger/safety/2g' testfile.txt

11. Заменить текст на определенной строке.

sed '4 s/danger/safety/' testfile.txt

Здесь мы явно указали что надо на 4 строке в файле testfile.txt заменить первое найденное слово danger на слово safety. Так же мы можем указать диапазон строк для поиска и последующей замены:

sed '4-9 s/danger/safety/' testfile.txt

12. Добавить строку до/после совпадения с заданным поиском.

Для добавления новой строки с неким содержимым после каждого найденного совпадения которое мы задали искать используйте опцию «a«:

sed '/danger/a "Это новая строка с текстом после найденного слова"' testfile.txt

Для добавления новой строки с неким содержимым перед каждым найденным совпадением которое мы задали искать используйте опцию «i«:

sed '/danger/i "Это новая строка с текстом вставленная до найденного совпадения поиска" ' testfile.txt

13.Замена всей строки при совпадении поиска.

Чтобы изменить целую строку на новую строку при совпадении шаблона поиска, нам нужно использовать опцию «c«:

sed '/danger/c "Строка со словом danger будет заменена на эту строку" ' testfile.txt

Продвинутые опции sed

14. Запуск нескольких команд sed.

Если нам нужно выполнить несколько выражений sed, мы можем использовать опцию «e» для объединения команд sed в цепочку:

sed -e 's/danger/safety/g' -e 's/hate/love/' testfile.txt

15. Создание резервной копии перед изменением файла.

Для создания резервной копии файла перед его изменением используем опцию «-i.bak«:

sed -i.bak -e 's/danger/safety/g' testfile.txt

Этак команда выполнит редактирование файла, но перед этим создаст его копию с расширением .bak. Вы можете, конечно же, использовать любое другое расширение.

Читайте также:  Install clion arch linux

16. Удаление текста начиная с указанного слова и заканчивая другим словом.

Чтобы удалить строку файла, начинающуюся с определенного слова и заканчивая другим словом выполните:

sed -e 's/danger.*stops//g' testfile.txt

В этом примере danger — слово начиная с которого будет удаляться, stops — где удаление завершится. Выражение «.*» указывает что между этими двумя словами может быть любое количество слов.

17. Добавление строк.

Чтобы добавить контент перед каждой строкой с помощью sed & regex, используйте команду:

sed -e 's/.*/testing sed &/' testfile.txt

Так мы перед каждой строкой добавим текст «testing sed».

18. Удаление всех комментариев и пустых строк.

Для удаления всех закомментированных строк (например начинающихся с #), а так же всех пустых строк выполните:

Для удаления только комментариев:

19. Получение списка пользователей из файла /etc/passwd.

Данная команда выведет на экран список пользовательских имён.

20. Запрет перезаписи системных ссылок с помощью команды sed.

При выполнении команды «sed -i» если вы редактируете не сам файл, а ссылку на него, файл ссылки будет удален и на его месте появится самый обычный файл. Чтобы этого не произошло, вам следует пользоваться опцией «—follow-symlinks»

К примеру мы захотели отключить SELinux на сервере с CentOS или RHEL:

sed -i --follow-symlinks 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/sysconfig/selinux

В этом примере sed проследует по символьной ссылке коей на самом деле является указанный файл «/etc/sysconfig/selinux» и отредактирует тот файл, на который эта ссылка указывает, вместо того чтобы редактировать файл ссылки как настоящий.

Источник

Оцените статью
Adblock
detector