Читать интересную книгу Искусство программирования на языке сценариев командной оболочки - Мендель Купер

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 33 34 35 36 37 38 39 40 41 ... 96

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

1 ... 33 34 35 36 37 38 39 40 41 ... 96
На этом сайте Вы можете читать книги онлайн бесплатно русская версия Искусство программирования на языке сценариев командной оболочки - Мендель Купер.
Книги, аналогичгные Искусство программирования на языке сценариев командной оболочки - Мендель Купер

Оставить комментарий