Действия

Bash: различия между версиями

Материал из lulzette's wiki

Нет описания правки
Нет описания правки
Строка 15: Строка 15:


== if ==
== if ==
* Квадратные скобки - if логический.
* Круглые скобки - if арифметический
https://www.gnu.org/software/bash/manual/html_node/Shell-Arithmetic.html


* <code>[ *условие* ] && команда </code> - выполнит команду если условие верно
* <code>[ *условие* ] && команда </code> - выполнит команду если условие верно
* <code>[ *условие* ] || команда </code> - выполнит команду если условие ложно
* <code>[ *условие* ] || команда </code> - выполнит команду если условие ложно
* <code>[ -f path ]</code> - Наличие файла
* <code>[ -d path ]</code> - Наличие директории


Условия-проверки:
Условия-проверки:
Строка 50: Строка 55:
* <code>-ge,(>=)</code> — больше или равно
* <code>-ge,(>=)</code> — больше или равно


{{#spoiler:
<quote>
<source>
Скобки
[ — является специальной встроенной командой test воспринимающей свои аргументы как выражение сравнения или файловую проверку […..].
 
[[ — расширенный вариант от «[«, является зарезервированным словом, а не командой, его bash выполняет как один элемент с кодом возврата. Внутри «[[….]]» разрешается выполнение операторов &&, || которые приводят к ошибке в обычных скобках «[….]» тем самым вариант с двойной скобкой более универсален.
 
(( — является арифметическими выражениями, которое так же возвращают код 0. Тем самым такие выражения могут участвовать в операциях сравнения.
 
Приведу список логических операторов, которые используются для if|then|else:
Приведу список логических операторов, которые используются для if|then|else:
-z  — строка пуста
-n — строка не пуста


=, ( == ) — строки равны
=, ( == ) — строки равны


!=  — строки неравны
!=  — строки неравны
-eq — равно
-ne — неравно
-lt,(< ) — меньше
-le,(<=) — меньше или равно
-gt,(>) — больше
-ge,(>=) — больше или равно


! — отрицание логического выражения
! — отрицание логического выражения
Строка 86: Строка 67:


-o,(||) — логическое «ИЛИ»
-o,(||) — логическое «ИЛИ»
</source>
</quote>
}}


== Башизмы ==
== Башизмы ==

Версия от 08:05, 18 января 2021

Красивости (oh-my-bash): https://github.com/ohmybash/oh-my-bash

AWK: awk

Tips&Tricks: http://mywiki.wooledge.org/BashPitfalls
Цикл статей от RuVDS: https://habr.com/ru/company/ruvds/blog/325522/

И в виде одного PDF

OpenNet: https://www.opennet.ru/docs/RUS/bash_scripting_guide/c2171.html

Подробная Bash Hackers Wiki: https://wiki.bash-hackers.org/start

if

  • Квадратные скобки - if логический.
  • Круглые скобки - if арифметический

https://www.gnu.org/software/bash/manual/html_node/Shell-Arithmetic.html


  • [ *условие* ] && команда - выполнит команду если условие верно
  • [ *условие* ] || команда - выполнит команду если условие ложно

Условия-проверки:

https://www.shellhacks.com/ru/bash-test-if-file-exists/

  • -e - файл (любой) существует
  • -f - файл (простой) существует
  • -d - директория существует

Условия-сравнения:

  • -z — строка пуста
  • -n — строка не пуста
  • -eq или =, ( == ) — равно
  • -ne или != — неравно
  • -lt,(< ) — меньше
  • -le,(<=) — меньше или равно
  • -gt,(>) — больше
  • -ge,(>=) — больше или равно

<quote> Приведу список логических операторов, которые используются для if|then|else:

=, ( == ) — строки равны

!= — строки неравны

! — отрицание логического выражения

-a,(&&) — логическое «И»

-o,(||) — логическое «ИЛИ» </quote>

Башизмы

Работа с файлами

Объём всех файлов/папок включая скрытые в текущей директории:

du -hs * .[^.]*


Перебор файлов в папке (echo заменить на требуемую команду):

for file in *; do echo $file; done;
# Например, для импорта большого количества таблиц БД:
for file in *; do mysql -u'USER' DB -p'PASS' < $file; done;


Если найдет sometext в файле из папки /some/dir, то скопирует всё содержимое этого файла в somefile.txt

grep -lR "sometext" /some/dir | xargs cat >> somefile.txt


Обединить сожержимое нескольких файлов в один (somefile), file* это шаблон для поиска нужных файлов:

ls -1 file* | xargs -n 1 -I {} cat {} >> somefile


Работа с текстом

Прочитать файл построчно и выполнить действие над строками (echo заменить на требуемую команду):

while IFS= read -r line; do echo $line; done < file.txt


Найти все вхождения подстроки (будет выведено каждое вхождение, для их подсчёта использовать `wc -l`):

cat file.txt | grep -o "pattern"


Удалить подстроку из STRING, найденную по регулярке PATTERN (работает только с gawk):

PATTERN='regexp'  # регулярку regexp необходимо записывать без операторных скобок (слэшей) вокруг
echo "$STRING" | awk -v pattern="$PATTERN"\
                      'match($0, pattern, matches)\
                      {
                          ext=matches[0]"$";
                          sub(ext, "");
                          print $0
                      }'


Поиск файлов с именами определённой длины. find найдёт все файлы с длиной имени от 3 до 5 символов не учитывая расширение (предусмотрено наличие точек и пробелов в имени):

find . -type f  -regextype posix-egrep -regex ".*/(.{3,5})\.([^\.]+)$"


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

$ cat file.txt
one
two
$ echo $(< file.txt)
one two


Удалить из файла строки, содержащие паттерн:

sed -i '/pattern/d' foobar.txt


Работа со строками

Вывести длину строки:

str='onetwo'; echo ${#str}  # в результате 3


Удалить пробелы в строке:

str='one two'; echo ${str//[[:blank:]]/}
# или
echo 'one two' | sed 's/ //g'


Количество слов в строке:

echo 'one two' | wc -w  # в результате 2


Найти вхождение между левым и правым выражениями:

echo "Here is a String" | sed -e 's/Here\(.*\)String/\1/'  # результат: "is a"


Замена подстроки и обрезка строки:

echo "${PWD//${HOME::(-1)}/\~}"
# В примере выше производится замена пути "/home/user" на "~/".
# $HOME содержит путь "/home/user/", поэтому вырезается последний символ тут: ${HOME::(-1)}