BASH
Любой bash скрипт начинается со следующей строки
#!/bin/bash
Переменная $0 - равна имени файла(скрипта). Допустим имя world и скрипт выглядит так
#!/bin/bash echo "Hello $0"
Запуск скрипта приведёт к выводу на экран
# ./world Hello world
Все следующие $1, $2 и т.д. переменные, это параметры которые передаём скрипту. Допустим переменные будут vasya, petya.
#!/bin/bash echo "My $0" echo 'Privet $1' echo 'Privet $2'
Результат
# ./script vasya petya My script Privet vasya Privet petya
Цикл if
#!/bin/bash if [ "$1" == "Vasya" ]; then echo "Privet $1" else [ "$1" == "Petya" ]; then echo "Privet $1" else echo "Zdarova $1" fi
Результаты
# ./script Zdarova # ./script Oleg Zdarova Oleg # ./script Vasya Privet Vasya # ./script Petya Privet Petya
Цикл if с case
#!/bin/bash if [ "$1" == "Vasya" ]; then echo "Privet $1" else [ "$1" == "Petya" ]; then echo "Privet $1" else echo "Zdarova $1" fi x=$2 echo "Starting case selection..." case $x in 1) echo "This is one";; [2-9]) echo "Two-nine";; "Petya") echo "Privet $x";; *) echo "Parameter unknown" esac
Результаты
# ./script Zdarova Starting case selection... Parameter unknown # ./script Oleg 3 Zdarova Oleg Starting case selection... Two-nine # ./script Petya 1 Privet Petya Starting case selection... This is one # ./script Vasya Petya Privet Vasya Starting case selection... Privet Petya # ./script Petya Alex Privet Petya Starting case selection... Parameter unknown
Интерактивный ввод параметра
#!/bin/bash if [ "$1" == "Vasya" ]; then echo "Privet $1" else [ "$1" == "Petya" ]; then echo "Privet $1" else echo "Zdarova $1" fi echo "Please entrer something: " read x # read -p "Please entrer something: " x - второй вариант echo "Starting case selection..." case $x in 1) echo "This is one";; [2-9]) echo "Two-nine";; "Petya") echo "Privet $x";; *) echo "Parameter unknown" esac
Результат
# ./script Oleg Zdarova Oleg Enter something: 2 Starting case selection... Two-nine
и т.д.
Циклы
#!/bin/bash COUNTER=0 while [$COUNTER -lt 10]; do # -lt(less than) - меньше чем echo "Current counter is $COUNTER" COUNTER=$((COUNTER+1)) done
Результат выведет переменные от 0 до 9
# ./script Current counter is 0 Current counter is 1 Current counter is 2 Current counter is 3 Current counter is 4 Current counter is 5 Current counter is 6 Current counter is 7 Current counter is 8 Current counter is 9
#!/bin/bash for myfile in `ls *.txt`; do cat $myfile done
Результат выведет содержимое файлов .txt
# ./script Text from file1 Text from file2 Text from file3
#!/bin/bash for x in {1..10}; do echo "X = $x" done
Результат выведет значение переменной от 1 до 10
# ./script X = 1 X = 2 X = 3 X = 4 X = 5 X = 6 X = 7 X = 8 X = 9 X = 10
#!/bin/bash for (( i=1; i<=10; i++ )); do echo "Nomer N = $i" done
Результат выведет значение переменной от 1 до 10
# ./script Nomer N = 1 Nomer N = 2 Nomer N = 3 Nomer N = 4 Nomer N = 5 Nomer N = 6 Nomer N = 7 Nomer N = 8 Nomer N = 9 Nomer N = 10
Стандартные ввод, вывод и ошибка
Существует три стандартных значения ввода и вывода для программ. Ввод получают от клавиатуры (интерактивная, диалоговая программа), или из программы, обрабатывающей вывод другой программы.
Результат программы обычно печатается в стандартной вывод и иногда в файл «STDERR» (ошибка).
Все это три дескриптора файла, которые часто называют STDIN, STDOUT и STDERR.
Но часто к ним обращаются не по имени, а по номеру:
0 — STDIN, 1 — STDOUT и 2 — STDERR
По умолчанию, если не указать номер, то будет подразумеваться STDOUT.
В следующем примере
cron job command > /dev/null 2>&1
видно, что команда направляет свой стандартный вывод в /dev/null (псевдоустройство, которое может принять произвольный объём данных, не сохраняя их совершенно нигде, следовательно, подавив стандартный вывод).
Затем все ошибки (то есть STDERR) перенаправляет в стандартный вывод. Перед номером потока, в который перенаправляем вывод, необходимо указывать амперсанд "&"
Перенаправить все ошибки в файл( >> допишет в файл)
cron job command 2> errors.txt
Перенаправить все нормальные ответы в один файл, а все ошибки в другой
grep TEXT /etc/* > good.txt 2> errors.txt
Перенаправить и нормальные ответы и ошибки в один файл
grep TEXT /etc/* &> all.txt
Завершение и код завершения
Команда exit может использоваться для завершения работы сценария, точно так же как и в программах на языке C. Кроме того, она может возвращать некоторое значение, которое может быть проанализировано вызывающим процессом.
Каждая команда возвращает код завершения (иногда код завершения называют возвращаемым значением ). В случае успеха команда должна возвращать 0, а в случае ошибки -- ненулевое значение, которое, как правило, интерпретируется как код ошибки. Практически все команды и утилиты UNIX возвращают 0 в случае успешного завершения, но имеются и исключения из правил.
Аналогичным образом ведут себя функции, расположенные внутри сценария, и сам сценарий, возвращая код завершения. Код, возвращаемый функцией или сценарием, определяется кодом возврата последней команды. Команде exit можно явно указать код возврата, в виде: exit nnn, где nnn -- это код возврата (число в диапазоне 0 - 255).
Код возврата последней команды хранится в специальной переменной $?. После исполнения кода функции, переменная $? хранит код завершения последней команды, исполненной в функции. Таким способом в Bash передается "значение, возвращаемое" функцией. После завершения работы сценария, код возврата можно получить, обратившись из командной строки к переменной $?, т.е. это будет код возврата последней команды, исполненной в сценарии.
Пример 6-1. завершение / код завершения
- !/bin/bash
echo hello echo $? # код возврата = 0, поскольку команда выполнилась успешно.
lskdf # Несуществующая команда. echo $? # Ненулевой код возврата, поскольку команду выполнить не удалось.
echo
exit 113 # Явное указание кода возврата 113.
# Проверить можно, если набрать в командной строке "echo $?" # после выполнения этого примера.
- В соответствии с соглашениями, 'exit 0' указывает на успешное завершение,
- + в то время как ненулевое значение означает ошибку.
Переменная $? особенно полезна, когда необходимо проверить результат исполнения команды (см. Пример 12-27 и Пример 12-13).
Note Символ !, может выступать как логическое "НЕ" для инверсии кода возврата.
Пример 6-2. Использование символа ! для логической инверсии кода возврата
true # встроенная команда "true". echo "код возврата команды \"true\" = $?" # 0
! true echo "код возврата команды \"! true\" = $?" # 1
- Обратите внимание: символ "!" от команды необходимо отделять пробелом.
- !true вызовет сообщение об ошибке "command not found"