Примечание
Для доступа к этой странице требуется авторизация. Вы можете попробовать войти или изменить каталоги.
Для доступа к этой странице требуется авторизация. Вы можете попробовать изменить каталоги.
Возвращает значение типа Double, задающее амортизацию актива по кумулятивному методу за указанный период.
Синтаксис
SYD(cost, salvage, life, period)
Функция SYD имеет следующие именованные аргументы:
Part | Описание |
---|---|
стоить | Обязательно. Тип Double; указывает начальную стоимость актива. |
спасение имущества | Обязательно. Тип Double; указывает ценность актива в конце его срока службы. |
Жизнь | Обязательно. Тип Double; указывает продолжительность срока службы актива. |
период | Обязательно. Тип Double; указывает период, за который рассчитывается амортизация актива. |
Замечания
Аргументы срока жизни и периода должны быть выражены в одних и том же единицах. Например, если аргумент life задается в месяцах, аргумент period должен также задаваться в месяцах. Все аргументы должны быть положительными числами.
Пример
В этом примере функция SYD используется для возврата амортизации актива за указанный период с учетом начальной стоимости актива (InitCost
), значения спасения в конце срока использования актива (SalvageVal
) и общего срока жизни актива в годах (LifeTime
). Период в годах, для которого рассчитывается амортизация, — PDepr
.
Dim Fmt, InitCost, SalvageVal, MonthLife, LifeTime, DepYear, PDepr
Const YEARMONTHS = 12 ' Number of months in a year.
Fmt = "###,##0.00" ' Define money format.
InitCost = InputBox("What's the initial cost of the asset?")
SalvageVal = InputBox("What's the asset's value at the end of its life?")
MonthLife = InputBox("What's the asset's useful life in months?")
Do While MonthLife < YEARMONTHS ' Ensure period is >= 1 year.
MsgBox "Asset life must be a year or more."
MonthLife = InputBox("What's the asset's useful life in months?")
Loop
LifeTime = MonthLife / YEARMONTHS ' Convert months to years.
If LifeTime <> Int(MonthLife / YEARMONTHS) Then
LifeTime = Int(LifeTime + 1) ' Round up to nearest year.
End If
DepYear = CInt(InputBox("For which year do you want depreciation?"))
Do While DepYear < 1 Or DepYear > LifeTime
MsgBox "You must enter at least 1 but not more than " & LifeTime
DepYear = CInt(InputBox("For what year do you want depreciation?"))
Loop
PDepr = SYD(InitCost, SalvageVal, LifeTime, DepYear)
MsgBox "The depreciation for year " & DepYear & " is " & Format(PDepr, Fmt) & "."
См. также
Поддержка и обратная связь
Есть вопросы или отзывы, касающиеся Office VBA или этой статьи? Руководство по другим способам получения поддержки и отправки отзывов см. в статье Поддержка Office VBA и обратная связь.