··J="$(scriptbc −p 8 $I / \(12 \* 100 \))"
··N="$(($L * 12))"
··M="$(scriptbc −p 8 $P \* \($J / \(1 — \(1 + $J\) \^ −$N\) \))"
··# Выполнить необходимые преобразования значений:
··dollars="$(echo $M | cut −d. -f1)"
··cents="$(echo $M | cut −d. -f2 | cut −c1-2)"
··cat << EOF
··A $L-year loan at $I % interest with a principal amount of $(nicenumber $P 1)
··results in a payment of \$$dollars.$cents each month for the duration of
··the loan ($N payments).
··EOF
··exit 0
Рассмотрение самих вычислений выходит за рамки этой книги, но обратите внимание, как сложную математическую формулу можно реализовать непосредственно в сценарии командной оболочки.
Другой способ выполнить все вычисления — передать один большой поток входных данных программе bc, потому что она поддерживает переменные. Однако возможность манипулировать промежуточными значениями внутри самого сценария доказывает, что он позволяет произвести часть вычислений без привлечения команды bc. Кроме того, деление формулы на несколько промежуточных вычислений
упрощает отладку. Например, следующий код разбивает вычисленные месячные платежи на доллары и центы и гарантирует правильное форматирование денежных сумм:
dollars="$(echo $M | cut −d. -f1)"
cents="$(echo $M | cut −d. -f2 | cut −c1-2)"
Команда cut оказывается здесь особенно полезной
. Вторая строка в этом коде извлекает из суммы месячного платежа ту часть, которая следует за десятичной точкой, и затем отсекает все, что следует за вторым символом. Если вы пожелаете округлить число до центов в бо́льшую сторону, просто прибавьте 0,005 к результату вычислений перед усечением центов до двух цифр.
Обратите внимание, как в строке
командой. library.sh подключается библиотечный сценарий, созданный в главе 1, что обеспечивает доступность всех функций (в данном сценарии используется функция nicenumber() из главы 1).
Этот коротенький сценарий принимает три параметра: сумма кредита, процентная ставка и срок кредита (в годах).
Представьте, что вы узнали о выходе новой модели Tesla Model S и вам интересно узнать, сколько придется заплатить, если купить ее в кредит. Стоимость модели Model S начинается примерно с 69 900 долларов, а ставка по кредиту составляет 4,75 % годовых. Допустим, что у вас уже есть автомобиль, за который вы выручите 25 000 долларов на вторичном рынке, и вам остается добавить 44 900. Недолго думая, вы можете сравнить суммы выплат по четырех- и пятилетнему автокредиту, просто воспользовавшись сценарием, показанным в листинге 3.11.
Листинг 3.11.Тестирование сценария loancalc
$ loancalc 44900 4.75 4
A 4-year loan at 4.75 % interest with a principal amount of 44,900
results in a payment of $1028.93 each month for the duration of
the loan (48 payments).
$ loancalc 44900 4.75 5
A 5-year loan at 4.75 % interest with a principal amount of 44,900
results in a payment of $842.18 each month for the duration of
the loan (60 payments).
Если вы в состоянии потянуть выплаты по четырехлетнему автокредиту, вы погасите его быстрее, и общая сумма выплат (произведение суммы месячного платежа на количество месяцев) значительно уменьшится. Чтобы подсчитать экономию, можно воспользоваться интерактивным калькулятором из сценария № 23, как показано ниже:
$ calc '(842.18 * 60) — (1028.93 * 48)'
1142.16
1142,16 доллара — хорошая экономия, этих денег хватит на отличный ноутбук!
Усовершенствование сценария
Этот сценарий мог бы запрашивать необходимые данные при запуске без параметров. Еще более полезная версия сценария могла бы предлагать пользователю ввести любые три параметра из четырех (сумма кредита, процентная ставка, срок и сумма месячных платежей) и автоматически вычислять четвертое значение. В этом случае, зная, что вы способны выплачивать только 500 долларов в месяц и максимальная ставка по пятилетнему автокредиту составляет 6 %, вы сумели бы определить максимальную сумму доступного для вас кредита. Подобные вычисления можно выполнять, реализовав поддержку разных флагов, которые пользователи передавали бы сценарию.
№ 26. Слежение за событиями
Следующая пара сценариев реализует простую программу-календарь, похожую на утилиту напоминания из сценария № 22. Первый сценарий, addagenda (представлен в листинге 3.12), позволяет определить событие, повторяющееся (в определенные дни недели, месяца или года) или однократное (в конкретный день, месяц и год). Все даты проверяются и сохраняются вместе с однострочным описанием события в файле .agenda , в домашнем каталоге пользователя. Второй сценарий, agenda (представлен в листинге 3.13), просматривает все сохраненные события и отыскивает запланированные на текущую дату.
Читать дальше