Дейв Тейлор - Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание
- Название:Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание
- Автор:
- Жанр:
- Издательство:Питер
- Год:2017
- Город:СПб.
- ISBN:978-5-496-03029-8
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Дейв Тейлор - Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание краткое содержание
Цель этой книги — продемонстрировать практические приемы программирования сценариев на bash и познакомить с самыми распространенными утилитами на коротких и компактных примерах, не вдаваясь в излишние подробности. Экспериментируйте с этими сценариями — ломайте, исправляйте и приспосабливайте их под свои нужды, чтобы понять, как они работают. Только так вы сможете решать самые сложные задачи.
Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
#·· а дробная — как положительное целое число. То есть число -30.5 оценивается
#·· как допустимое, а -30.-8 нет.
# Подключение других сценариев к текущему осуществляется с помощью оператора"."
# Довольно просто.
. validint
validfloat()
{
··fvalue="$1"
··# Проверить наличие десятичной точки.
··if [! -z $(echo $fvalue | sed 's/[^.]//g')]; then
····# Извлечь целую часть числа, слева от десятичной точки.
····decimalPart="$(echo $fvalue | cut −d. -f1)"
····# Извлечь дробную часть числа, справа от десятичной точки.
····fractionalPart="${fvalue#*\.}"
····# Проверить целую часть числа, слева от десятичной точки
····if [! -z $decimalPart]; then
······# "!" инвертирует логику проверки, то есть ниже проверяется
······#·· "если НЕ допустимое целое число"
······if! validint "$decimalPart" "" ""; then
········return 1
······fi
····fi
····# Теперь проверим дробную часть.
····# Прежде всего, она не может содержать знак "минус" после десятичной точки,
····#·· например: 33.-11, поэтому проверим знак '-’ в дробной части.
····if ["${fractionalPart%${fractionalPart#?}}" = "-"]; then
······echo "Invalid floating-point number: '-' not allowed \
········after decimal point." >&2
······return 1
····fi
····if ["$fractionalPart"!= ""]; then
······# Если дробная часть НЕ является допустимым целым числом…
······if! validint "$fractionalPart" "0" ""; then
········return 1
······fi
····fi
··else
····# Если все значение состоит из единственного знака "-",
····#·· это недопустимое значение.
····if ["$fvalue" = "-"]; then
······echo "Invalid floating-point format." >&2
······return 1
····fi
····# В заключение проверить, что оставшиеся цифры представляют
····# допустимое целое число.
····if! validint "$fvalue" "" ""; then
······return 1
····fi
··fi
··return 0
}
Как это работает
Сценарий сначала проверяет наличие десятичной точки во входном значении . Если точки в числе нет, это не вещественное число. Далее для анализа извлекаются целая
и дробная
части числа. Затем, в строке
, сценарий проверяет, является ли целая часть ( слева от десятичной точки) допустимым целым числом. Следующая последовательность проверок сложнее, потому что требуется проверить
отсутствие дополнительного знака «минус» (чтобы исключить такие странные числа, как 17. –30) и убедиться, что дробная часть ( справа от десятичной точки) является допустимым целым числом.
Последняя проверка в строке выясняет, не является ли проверяемое значение единственным знаком «минус» (такое число выглядело бы слишком странно, чтобы пропустить его).
Все проверки выполнились успешно? Тогда сценарий возвращает 0, указывающий, что ввод пользователя содержит допустимое вещественное число.
Запуск сценария
Если во время выполнения функции не будет выведено сообщения об ошибке, она вернет 0 для числа, являющегося допустимым вещественным значением. Чтобы протестировать сценарий, добавьте в конец следующие строки кода:
if validfloat $1; then
··echo "$1 is a valid floating-point value."
fi
exit 0
Если попытка подключить сценарий validint сгенерирует ошибку, убедитесь, что он находится в одном из каталогов, перечисленных в PATH, или просто скопируйте функцию validint непосредственно в начало сценария validfloat.
Результаты
Сценарий validfloat принимает единственный аргумент для проверки. Листинг 1.13 демонстрирует проверку нескольких значений с помощью validfloat.
Листинг 1.13.Тестирование сценария validfloat
$ validfloat 1234.56
1234.56 is a valid floating-point value.
$ validfloat -1234.56
-1234.56 is a valid floating-point value.
$ validfloat —.75
-.75 is a valid floating-point value.
$ validfloat -11.-12
Invalid floating-point number: '-' not allowed after decimal point.
$ validfloat 1.0344e22
Invalid number format! Only digits, no commas, spaces, etc.
Если вы увидите лишний вывод, это может объясняться присутствием строк, добавленных ранее в validint для тестирования, которые вы забыли удалить перед переходом к этому сценарию. Просто вернитесь назад, к описанию сценария № 5 и закомментируйте или удалите строки, добавленные для тестирования функции.
Усовершенствование сценария
Было бы круто добавить в функцию поддержку научной формы записи, продемонстрированной в последнем примере. Это не так уж трудно. Вам нужно проверить присутствие в числе символа 'e’ или 'E’ и затем разбить его на три сегмента: целую часть (всегда представлена единственной цифрой), дробную часть и степень числа 10. После этого каждую часть можно проверить с помощью validint.
№ 7. Проверка форматов дат
Одна из наиболее сложных, но очень важная команда проверки — это проверка допустимости дат. Если не принимать в расчет високосные годы, задача не кажется особенно трудной, потому что каждый год календарь остается неизменным. В данном случае достаточно иметь таблицу с числом дней в месяцах и использовать ее для проверки каждой конкретной даты. Чтобы учесть високосные годы, нужно добавить в сценарий дополнительную логику, и именно этот аспект вызывает наибольшие сложности.
Ниже приводится набор критериев, проверка которых позволяет сказать, является ли проверяемый год високосным:
• Если год не кратен 4, он не високосный .
• Если год делится на 4 и на 400 — это високосный год.
• Если год делится на 4 и не делится на 400, но делится на 100 — это не високосный год.
• Все остальные годы, кратные 4, являются високосными .
Просматривая исходный код в листинге 1.14, обратите внимание, что для нормализации исходной даты перед проверкой этот сценарий использует normdate.
Код
Листинг 1.14.Сценарий valid-date
··#!/bin/bash
··# valid-date — Проверяет дату с учетом правил определения високосных лет
··normdate="укажите здесь имя файла, в котором вы сохранили сценарий normdate.sh"
Интервал:
Закладка: