b=`expr $a <= 3`
echo "Если a <= 3, то b = 1 (истина)"
echo "b = $b" # 1 ( 3 -le 3 )
# Существует еще оператор ">=" (больше или равно).
echo
echo
# Операции сравнения
# -------- ---------
echo "Операции сравнения"
echo
a=zipper
echo "a is $a"
if [ `expr $a = snap` ]
then
echo "a -- это не zipper"
fi
echo
echo
# Операции со строками
# -------- -- --------
echo "Операции со строками"
echo
a=1234zipper43231
echo "Строка над которой производятся операции: "$a"."
# length: длина строки
b=`expr length $a`
echo "длина строки "$a" равна $b."
# index: позиция первого символа подстроки в строке
b=`expr index $a 23`
echo "Позиция первого символа "2" в строке "$a" : "$b"."
# substr: извлечение подстроки, начиная с заданной позиции, указанной длины
b=`expr substr $a 2 6`
echo "Подстрока в строке "$a", начиная с позиции 2,
и длиной в 6 символов: "$b"."
# При выполнении поиска по шаблону, по-умолчанию поиск
#+ начинается с ***начала*** строки.
#
# Использование регулярных выражений
b=`expr match "$a" '[0-9]*'` # Подсчет количества цифр.
echo Количество цифр с начала строки "$a" : $b.
b=`expr match "$a" '([0-9]*)'` # Обратите внимание на экранирование круглых скобок
# == ==
echo "Цифры, стоящие в начале строки "$a" : "$b"."
echo
exit 0
Вместо оператора match можно использовать оператор :. Например, команда b=`expr $a : [0-9]*` является точным эквивалентом для b=`expr match $a [0-9]*` в примере, рассмотренном выше.
#!/bin/bash
echo
echo "Операции над строками с использованием конструкции "expr $string : " "
echo "========================================================================"
echo
a=1234zipper5FLIPPER43231
echo "Строка, над которой выполняются операции: "`expr "$a" : '(.*)'`"."
# Экранирование круглых скобок в шаблоне == ==
# Если скобки не экранировать...
#+ то 'expr' преобразует строковый операнд в целое число.
echo "Длина строки "$a" равна `expr "$a" : '.*'`." # Длина строки
echo "Количество цифр с начала строки "$a" равно `expr "$a" : '[0-9]*'`."
# ------------------------------------------------------------------------- #
echo
echo "Цифры, стоящие в начале строки "$a" : `expr "$a" : '([0-9]*)'`."
# == ==
echo "Первые 7 символов в строке "$a" : `expr "$a" : '(.......)'`."
# ====== == ==
# Опять же, необходимо экранировать круглые скобки в шаблоне.
#
echo "Последние 7 символов в строке "$a" : `expr "$a" : '.*(.......)'`."
# ========= оператор конца строки ^^
# (фактически означает переход через любое количество символов, пока
#+ не будет найдена требуемая подстрока)
echo
exit 0
Этот пример демонстрирует необходимость экранирования оператора группировки -- ( ... ) в регулярных выражениях, при поиске по шаблону командой expr.
Perl, sed и awk имеют в своем распоряжении более мощный аппарат анализа строк. Коротенький скрипт на sed или awk, внутри сценария (см. Section 33.2) -- значительно более привлекательная альтернатива использованию expr при анализе строк.
Дополнительные примеры, по обработке строк, вы найдете в Section 9.2.
12.3. Команды для работы с датой и временем
Время/дата и измерение интервалов времени
date
Команда date без параметров выводит дату и время на стандартное устройство вывода stdout. Она становится гораздо интереснее при использовании дополнительных ключей форматирования вывода.
Пример 12-7. Команда date
#!/bin/bash
# Примеры использования команды 'date'
echo "Количество дней, прошедших с начала года: `date +%j`."
# Символ '+' обязателен при использовании форматирующего аргумента
# %j, возвращающего количество дней, прошедших с начала года.
echo "Количество секунд, прошедших с 01/01/1970 : `date +%s`."
# %s количество секунд, прошедших с начала "эпохи UNIX",
#+ но насколько этот ключ полезен?
prefix=temp
suffix=`eval date +%s` # Ключ "+%s" характерен для GNU-версии 'date'.
filename=$prefix.$suffix
echo $filename
# Прекрасный способ получения "уникального" имени для временного файла,
#+ даже лучше, чем с использованием $$.
# Дополнительную информацию вы найдете в 'man date'.
exit 0
Ключ -u дает UTC время (Universal Coordinated Time -- время по Гринвичу).
bash$ date
Fri Mar 29 21:07:39 MST 2002
bash$ date -u
Sat Mar 30 04:07:42 UTC 2002
zdump
Отображает время для указанной временной зоны.
bash$ zdump EST
EST Tue Sep 18 22:09:22 2001 EST
time
Выводит подробную статистику по исполнению некоторой команды.
time ls -l / даст нечто подобное:
0.00user 0.01system 0:00.05elapsed 16%CPU (0avgtext+0avgdata 0maxresident)k
0inputs+0outputs (149major+27minor)pagefaults 0swaps
См. так же очень похожую команду times, обсуждавшуюся в предыдущем разделе.
Начиная с версии 2.0 Bash, команда time стала зарезервированным словом интерпретатора, с несколько измененным поведением в конвейере.
touch
Утилита устанавливает время последнего обращения/изменения файла в текущее системное время или в заданное время, но так же может использоваться для создания нового пустого файла. Команда touch zzz создаст новый пустой файл с именем zzz, если перед этим файл zzz отсутствовал. Кроме того, такие пустые файлы могут использоваться для индикации, например, времени последнего изменения в проекте.
Эквивалентом команды touch могут служить : >> newfile или >> newfile (для обычных файлов).
at
Команда at -- используется для запуска заданий в заданное время. В общих чертах она напоминает crond, однако, at используется для однократного запуска набора команд.
at 2pm January 15 -- попросит ввести набор команд, которые необходимо запустить в указанное время. Эти команды должны быть совместимыми со сценариями командной оболочки. Ввод завершается нажатием комбинации клавиш Ctl-D.
Ключ -f или операция перенаправления ввода (<), заставляет at прочитать список команд из файла. Этот файл должен представлять из себя обычный сценарий, на языке командной оболочки и, само собой разумеется, такой сценарий должен быть неинтерактивным. Может использоваться совместно с командой run-parts для запуска различных наборов сценариев.
bash$ at 2:30 am Friday < at-jobs.list
job 2 at 2000-10-27 02:30
batch
Команда batch, управляющая запуском заданий, напоминает команду at, но запускает список команд только тогда, когда загруженность системы упадет ниже .8. Подобно команде at, с ключом -f, может считывать набор команд из файла.
cal
Выводит на stdout аккуратно отформатированный календарь на текущий месяц. Может выводить календарь за определенный год.
sleep
Приостанавливает исполнение сценария на заданное количество секунд, ничего не делая. Может использоваться для синхронизации процессов, запущенных в фоне, проверяя наступление ожидаемого события так часто, как это необходимо. Например, Пример 29-6.
sleep 3
# Пауза, длительностью в 3 секунды.
Команда sleep по-умолчанию принимает количество секунд, но ей можно передать и количество часов и минут и даже дней.
sleep 3 h
# Приостановка на 3 часа!
Для запуска команд через заданные интервалы времени лучше использовать watch .
usleep