Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на Basic / VBA


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный платный хостинг на базе Windows 2008

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

Гаряка Асмик
Статус: Бакалавр
Рейтинг: 1632
∙ повысить рейтинг »
Vasiliy83
Статус: Бакалавр
Рейтинг: 1154
∙ повысить рейтинг »
Megaloman
Статус: Бакалавр
Рейтинг: 980
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / Basic/VBA

Номер выпуска:982
Дата выхода:01.02.2010, 09:30
Администратор рассылки:Калашников О.А., Руководитель
Подписчиков / экспертов:371 / 100
Вопросов / ответов:1 / 1

Вопрос № 176335: Уважаемые эксперты, подскажите в следующем: Месяц = "5" Дата = "22.09.2010" Результат = DateDiff("m", Месяц, Дата) Результат_после_перевода_формата = Format(Результат, "dd mmmm yyyy г.") 'получа...



Вопрос № 176335:

Уважаемые эксперты, подскажите в следующем:
Месяц = "5"
Дата = "22.09.2010"
Результат = DateDiff("m", Месяц, Дата)
Результат_после_перевода_формата = Format(Результат, "dd mmmm yyyy г.") 'получаем 20 августа 1903 г., почему так происходит ????
'как сделать, чтобы было правильно, и если учесть, что ещё возможно будут отниматься и месяцы и дни ????
Спасибо Эндрю

Отправлен: 27.01.2010, 09:15
Вопрос задал: Ципихович Эндрю, Посетитель
Всего ответов: 1
Страница вопроса »


Отвечает Megaloman, Бакалавр :
Здравствуйте, Ципихович Эндрю. Вот код, результат его работы в приложении, скачать рабочий пример можно здесь 6666.doc (38.5 кб).
Код:
Месяц = 5                       ' На сколько месяцев пересчитать дату
Дни = 6 ' На сколько дней пересчитать дату
Лет = 4 ' На сколько лет пересчитать дату

Дата = "22.09.2010" ' Исходная Дата в символьном виде

ДатаDate = DateValue(Дата) ' преобразую дату из символьного типа в тип дата

Selection.TypeText Text:="-------------------------------------------" + vbCrLf
Selection.TypeText Text:="Пример 1 - к исходной дате добавим месяцы& quot; + vbCrLf

Результат = DateAdd("m", Месяц, ДатаDate)

Результат_после_перевода_формата = Format(Результат, "dd mmmm yyyy г.")
Selection.TypeText Text:=" Исходная дата " + Дата + vbCrLf
Selection.TypeText Text:=CStr(Месяц) + " месяцев добавили" + vbCrLf
Selection.TypeText Text:=Результат_после_перевода_формата + vbCrLf

Selection.TypeText Text:="-------------------------------------------" + vbCrLf
Selection.TypeText Text:="Пример 2 - от исходной даты отнимем месяцы" + vbCrLf

Результат = DateAdd("m", -Месяц, ДатаDate)

Результат_после_перевода_формата = Format(Результат, "dd mmmm yyyy г.")
Selection.TypeText Text:=" Исходная дата " + Дата + vbCrLf
Selection.TypeText Text:=CStr(Месяц) + " месяцев вычли" + vbCrLf
Selection.TypeText Text:=Результат_после_перевода_формата + vbCrLf

Selection.TypeText Text:="------- ------------------------------------" + vbCrLf
Selection.TypeText Text:="Пример 3 - от исходной даты отнимем дни" + vbCrLf

Результат = DateAdd("d", -Дни, ДатаDate)

Результат_после_перевода_формата = Format(Результат, "dd mmmm yyyy г.")
Selection.TypeText Text:=" Исходная дата " + Дата + vbCrLf
Selection.TypeText Text:=CStr(Дни) + " дней вычли" + vbCrLf
Selection.TypeText Text:=Результат_после_перевода_формата + vbCrLf

Selection.TypeText Text:="-------------------------------------------" + vbCrLf
Selection.TypeText Text:="Пример 4 - от исходной даты отнимем годы" + vbCrLf

Результат = DateAdd("yyyy", -Лет, ДатаDate)

Результат_после_перевода_формата = Format(Результат, "dd mmmm yyyy г.")
Selection.TypeText Text:=" Исходная дата " + Дата + vbCrLf
Selection.TypeText Text:=CStr(Лет) + " лет вычли" + vbCrLf
Se lection.TypeText Text:=Результат_после_перевода_формата + vbCrLf

Selection.TypeText Text:="-------------------------------------------" + vbCrLf
Selection.TypeText Text:="Пример 5 - от исходной даты отнимем годы месяцы дни" + vbCrLf

Результат = DateAdd("yyyy", -Лет, ДатаDate)
Результат = DateAdd("m", -Месяц, Результат)
Результат = DateAdd("d", -Дни, Результат)

Результат_после_перевода_формата = Format(Результат, "dd mmmm yyyy г.")
Selection.TypeText Text:=" Исходная дата " + Дата + vbCrLf
Selection.TypeText Text:=CStr(Лет) + " лет вычли" + vbCrLf
Selection.TypeText Text:=CStr(Месяц) + " месяцев вычли" + vbCrLf
Selection.TypeText Text:=CStr(Дни) + " дней вычли" + vbCrLf
Selection.TypeText Text:=Результат_после_перевода_формата + vbCrLf
Извините, если сообщаю известное, но если в в редакторе макроса выделить наименован ие функции и нажать F1, то получим справку по функции, правда, на английском. Но фундаментальных знаний английского там не надо.

Приложение:

-----
Нет времени на медленные танцы

Ответ отправил: Megaloman, Бакалавр
Ответ отправлен: 27.01.2010, 20:05
Номер ответа: 259009

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 259009 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:

  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2010.6.14 от 23.01.2010

    В избранное