Excel vba время как текст

Преобразование чисел, дат и строк в настраиваемый текстовый формат из кода VBA Excel с помощью функции Format. Синтаксис, параметры, символы, примеры.

Format – это функция, которая преобразует число, дату или строку в текст, отформатированный в соответствии с именованным выражением формата или инструкциями, составленными из специальных символов.

Синтаксис и параметры

Format(Expression, [FormatExpression], [FirstDayOfWeek], [FirstWeekOfYear])

  • Expression – любое допустимое выражение (переменная), возвращающее числовое значение или строку (обязательный параметр).
  • FormatExpression – выражение формата, именованное или содержащее инструкции из специальных символов (необязательный параметр).
  • FirstDayOfWeek – константа, задающая первый день недели (необязательный параметр).
  • FirstWeekOfYear – константа, задающая первую неделю года (необязательный параметр).

Именованные выражения форматов

Именные форматы даты и времени

Имя формата Описание
General Date Стандартное отображение даты и времени в соответствии с параметрами системы.
Long Date Длинный формат даты.
Medium Date Средний формат даты.
Short Date Краткий формат даты.
Long Time Длинный формат времени.
Medium Time Средний формат времени.
Short Time Краткий формат времени.

Проверьте отображение даты и времени с использованием именованных форматов на вашем компьютере при помощи следующего кода VBA Excel:

Sub FormatDateTime()

MsgBox «General Date:  « & Format(Now, «General Date») & vbNewLine _

& vbNewLine & «Long Date:  « & Format(Now, «Long Date») & vbNewLine _

& vbNewLine & «Medium Date:  « & Format(Now, «Medium Date») & vbNewLine _

& vbNewLine & «Short Date:  « & Format(Now, «Short Date») & vbNewLine _

& vbNewLine & «Long Time:  « & Format(Now, «Long Time») & vbNewLine _

& vbNewLine & «Medium Time:  « & Format(Now, «Medium Time») & vbNewLine _

& vbNewLine & «Short Time:  « & Format(Now, «Short Time»)

End Sub

Скорее всего, результат будет таким:

Отображение даты и времени в соответствии с именованными форматами

Именованные форматы чисел

Имя формата Описание
General Number Стандартное отображение числа без знака разделителя групп разрядов.
Currency Денежный формат.
Fixed Отображение числа без знака разделителя групп разрядов с двумя цифрами после разделителя целой и дробной части.
Standard Отображение числа со знаком разделителя групп разрядов и с двумя цифрами после разделителя целой и дробной части.
Percent Процентный формат: отображение числа, умноженного на 100, со знаком процента (%), добавленного справа.
Scientific Отображение числа в экспоненциальном виде.
Yes/No Возвращается «Нет», если число равно 0, иначе отображается «Да».
True/False Возвращается «Ложь», если число равно 0, иначе отображается «Истина».
On/Off Возвращается «Выкл», если число равно 0, иначе отображается «Вкл».

Проверяем работу именованных форматов на числах 2641387.7381962 и 0 с помощью кода VBA Excel:

Sub FormatNumber()

Dim n As Double

n = 2641387.7381962

‘n = 0

MsgBox «Форматируемое число = « & n & vbNewLine _

& vbNewLine & «General Number:  « & Format(n, «General Number») & vbNewLine _

& vbNewLine & «Currency:  « & Format(n, «Currency») & vbNewLine _

& vbNewLine & «Fixed:  « & Format(n, «Fixed») & vbNewLine _

& vbNewLine & «Standard:  « & Format(n, «Standard») & vbNewLine _

& vbNewLine & «Percent:  « & Format(n, «Percent») & vbNewLine _

& vbNewLine & «Scientific:  « & Format(n, «Scientific») & vbNewLine _

& vbNewLine & «Yes/No:  « & Format(n, «Yes/No») & vbNewLine _

& vbNewLine & «True/False:  « & Format(n, «True/False») & vbNewLine _

& vbNewLine & «On/Off:  « & Format(n, «On/Off»)

End Sub

Получаем следующий результат:

Отображение числа в соответствии с именованными форматамиОтображение нуля в соответствии с именованными форматами числа

Вместо вопросительного знака в отображении числа в формате Currency, по идее, должен быть знак валюты (₽ или руб.).

Специальные символы для выражений форматов

Символы для форматов даты и времени

Символ Описание
Точка (.) Разделитель компонентов даты (день, месяц, год). Используется при отображении месяца в виде числа.
Пробел Разделитель компонентов даты (день, месяц, год). Используется при отображении месяца прописью.
Двоеточие (:) Разделитель компонентов времени (часы, минуты, секунды).
d День в виде числа без нуля в начале (1–31).
dd День в виде числа с нулем в начале (01–31).
m Месяц в виде числа без нуля в начале (1–12). Если (m) следует после (h) или (hh), отображаются минуты (0–59).
mm Месяц в виде числа с нулем в начале (01–12). Если (mm) следует после (h) или (hh), отображаются минуты (00–59).
mmm Месяц прописью в сокращенном виде (янв–дек).
mmmm Полное название месяца (январь–декабрь).
y День года в виде числа (1–366).
yy Год в виде 2-значного числа (00–99).
yyyy Год в виде 4-значного числа (1900–9999).
h Часы в виде числа без нуля в начале (0–23).
hh Часы в виде числа с нулем в начале (00–23).
n (m) Минуты в виде числа без нуля в начале (0–59).
nn (mm) Минуты в виде числа с нулем в начале (00–59).
s Секунды в виде числа без нуля в начале (0–59).
ss Секунды в виде числа с нулем в начале (00–59).

В этой таблице перечислены далеко не все символы для выражений форматов даты и времени. Вы можете ознакомиться со всеми символами, в том числе и для форматирования чисел, на сайте разработчика.

Примеры отображения даты с помощью разных по количеству наборов символа d:

Sub DataIsD()

MsgBox «d:  « & Format(Now, «d») & vbNewLine _

& vbNewLine & «dd:  « & Format(Now, «dd») & vbNewLine _

& vbNewLine & «ddd:  « & Format(Now, «ddd») & vbNewLine _

& vbNewLine & «dddd:  « & Format(Now, «dddd») & vbNewLine _

& vbNewLine & «ddddd:  « & Format(Now, «ddddd») & vbNewLine _

& vbNewLine & «dddddd:  « & Format(Now, «dddddd»)

End Sub

Форматы даты, полученные с помощью разных по количеству наборов символа d

Символы для числовых форматов

Символ Описание
Точка (.) Десятичный разделитель.
Запятая (,) Разделитель групп разрядов. В отображаемых числах заполняется пробелом.
(0) Заполнитель, который отображает цифру или ноль. Используется, когда нужны ведущие нули или нули в конце числа.
(#) Заполнитель, который отображает цифру или ничего не отображает. Используется, когда не нужны ведущие нули или нули в конце числа.
(%) Заполнитель процента. Выражение умножается на 100, а знак процента (%) вставляется на той позиции, где он указан в строке формата.
(E- E+ e- e+) Экспоненциальный формат.

Примеры использования символов в выражениях числовых форматов VBA Excel:

Sub FormatNumber2()

Dim n As Double

n = 2641387.7381962

‘n = 0.2397842

MsgBox «Форматируемое число = « & n & vbNewLine _

& vbNewLine & «0.##:  « & Format(n, «0.##») & vbNewLine _

& vbNewLine & «000.###:  « & Format(n, «000.###») & vbNewLine _

& vbNewLine & «#,###.###:  « & Format(n, «#,###.###») & vbNewLine _

& vbNewLine & «0 %:  « & Format(n, «0 %») & vbNewLine _

& vbNewLine & «0.### E-:  « & Format(n, «0.### E-«) & vbNewLine _

& vbNewLine & «0.### E+:  « & Format(n, «0.### E+»)

End Sub

Символы для текстовых форматов

Символ Описание
At-символ (@) Заполнитель для символов, отображающий знак или пробел.
Амперсанд (&) Заполнитель для символов, отображающий знак или ничего (пустая строка).
Меньше (<) Принудительный перевод всех буквенных символов в нижний регистр.
Больше (>) Принудительный перевод всех буквенных символов в верхний регистр.

Примеры использования символов в выражениях строковых форматов VBA Excel:

Sub FormatString()

MsgBox «Номер телефона:  « & Format(«1234567890», «+7 (@@@) @@@-@@-@@») & vbNewLine _

& vbNewLine & «Серия и номер паспорта:  « & Format(«1234567890», «&& && &&&&») & vbNewLine _

& vbNewLine & «Нижний регистр:  « & Format(«Нижний регистр», «<«) & vbNewLine _

& vbNewLine & «Верхний регистр: « & Format(«Верхний регистр», «>»)

End Sub

Результаты форматирования строк с помощью специальных символов для функции Format

Форматы для различных значений одного выражения

Различные форматы для разных числовых значений

В выражении формата для чисел предусмотрено от одного до четырех разделов, отделяемых друг от друга точкой с запятой. Отображаемая строка зависит от значения, возвращенного параметром Expression функции Format.

Количество разделов Результат форматирования
Один раздел Выражение формата применяется ко всем значениям.
Два раздела Первый раздел применяется к положительным значениям и нулям, второй – к отрицательным значениям.
Три раздела Первый раздел применяется к положительным значениям, второй – к отрицательным значениям, третий – к нулям.
Четыре раздела Первый раздел применяется к положительным значениям, второй – к отрицательным значениям, третий – к нулям, четвертый – к значениям Null.

Пример использования четырех разделов в выражении формата числовых значений:

Sub FormatDifferentValues()

MsgBox «Число 1234,5678:  « & _

Format(1234.5678, «#,##0.00 руб.;Отрицательное число;Ноль рублей;Значение Null») _

& vbNewLine & vbNewLine & «Число -25:  « & _

Format(25, «#,##0.00 руб.;Отрицательное число;Ноль рублей;Значение Null») _

& vbNewLine & vbNewLine & «Число 0:  « & _

Format(0, «#,##0.00 руб.;Отрицательное число;Ноль рублей;Значение Null») _

& vbNewLine & vbNewLine & «Null:  « & _

Format(Null, «#,##0.00 руб.;Отрицательное число;Ноль рублей;Значение Null»)

End Sub

Различные форматы для разных строковых значений

В выражении формата для строк предусмотрено до двух разделов, отделяемых друг от друга точкой с запятой. Отображаемая строка зависит от текста, возвращенного параметром Expression функции Format.

Количество разделов Результат форматирования
Один раздел Выражение формата применяется ко всем строковым данным.
Два раздела Первый раздел применяется к строковым данным, второй – к значениям Null и пустым строкам («»).

Пример использования двух разделов в выражении формата строк:

Sub FormatString2()

MsgBox «Строка «Белка»:  « & _

Format(«Белка», «@;Пустая строка или Null») _

& vbNewLine & vbNewLine & «Пустая строка:  « & _

Format(«», «@;Пустая строка или Null») _

& vbNewLine & vbNewLine & «Строка «Null»:  « & _

Format(«Null», «@;Пустая строка или Null») _

& vbNewLine & vbNewLine & «Значение Null:  « & _

Format(Null, «@;Пустая строка или Null»)

End Sub

Доброго времени суток.  
Возникли следующие вопросы по использованию VBA в MS Excel:  
1. Есть колонка в которой расположены данные вида 06.06.2011. Формат ячеек: Дата 14.03.2001. Как преобразовать эту колонку при помощи VBA, чтобы формат данных изменился на текстовый, а отображение данных не изменилось?  
2. Есть колонка в которой расположены данные вида 15:45:00. Формат ячеек: (все форматы) ч:мм:сс. Как преобразовать эту колонку при помощи VBA, чтобы формат данных изменился на текстовый, а отображение данных не изменилось?  
3. Ну раз уж пошла такая пьянка… На всякий случай задам и третий. Если в первой колонке расположены данные в формате, описанном в первом вопросе, а во второй колонке расположены данные в формате, описанном во втором вопросе, то как получить в третьей колонке данные в текстовом формате, и чтобы отображались они в следующем виде: 06.06.2011 15:45? И, естественно, всё это при помощи VBA.  

  Заранее благодарен всем откликнувшимся.

Макрос преобразования даты в текст, и время в текст

romik85

Дата: Четверг, 16.01.2014, 09:36 |
Сообщение № 1

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

Добрый день, помогите плз с макросом.
данный макрос преобразует только дату в текстовое значение, но необходимо преобразовать и время в текстовое значение, но без добавления 0 в начало значения 9:00:01, т.е не должно быть после преобразования 09:00:01

[vba]

Код

Sub Текст()
For Each cell In Selection
cell.Formula = cell.Text
Next cell
MsgBox «готов»
End Sub

[/vba]

заранее спасибо!

К сообщению приложен файл:

2134187.xls
(30.5 Kb)

Сообщение отредактировал romik85Пятница, 17.01.2014, 01:31

 

Ответить

KuklP

Дата: Четверг, 16.01.2014, 13:50 |
Сообщение № 2

Группа: Проверенные

Ранг: Старожил

Сообщений: 2369


Репутация:

486

±

Замечаний:
0% ±


2003-2010

[vba]

Код

cell.value = format(cell,»h:mm:ss»)

[/vba]


Ну с НДС и мы чего-то стoим! kuklp60@gmail.com
WM Z206653985942, R334086032478, U238399322728

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 00:56 |
Сообщение № 3

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

спасибо что ответили, но данный код, преобразует ячейку с текстовым форматов в ячейку с форматом время.
необходимо преобразовать ячейку с форматом время, в ячейку с форматом текст.
приходится сцеплять много строк даты со временем, и время создает некоторую проблемку(.

Сообщение отредактировал romik85Пятница, 17.01.2014, 01:25

 

Ответить

RAN

Дата: Пятница, 17.01.2014, 01:45 |
Сообщение № 4

Группа: Друзья

Ранг: Экселист

Сообщений: 5645

Ниче не понял.
Зачем что-то в текст превращать? Дата со временем и так сцепляется.

К сообщению приложен файл:

7938623.xls
(32.0 Kb)


Быть или не быть, вот в чем загвоздка!

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 01:54 |
Сообщение № 5

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

03.06.2013 0,375023148148148 нет времени, + тоже выход, но хотелось бы макрос

Сообщение отредактировал romik85Пятница, 17.01.2014, 01:55

 

Ответить

Michael_S

Дата: Пятница, 17.01.2014, 01:57 |
Сообщение № 6

Группа: Друзья

Ранг: Старожил

Сообщений: 2012


Репутация:

373

±

Замечаний:
0% ±


Excel2016


[vba]

Код

Sub Текст()
Dim cell, a$
For Each cell In Selection
a = Format(cell, «h:mm:ss»)
cell.NumberFormat = «@»
cell.Value = a
Next cell
MsgBox «готов»
End S

[/vba]ub

 

Ответить

SkyPro

Дата: Пятница, 17.01.2014, 02:00 |
Сообщение № 7

Группа: Друзья

Ранг: Старожил

Сообщений: 1206


Репутация:

255

±

Замечаний:
0% ±


2010

Странная задача..
[vba]

Код

Function DateTimeToText$(dateRange As Range)
Dim rCell As Range
‘application.Volatile ‘раскомментировать, если нужен автопересчет функции.
For Each rCell In dateRange
     If rCell.Text <> «» Then
         DateTimeToText = DateTimeToText & rCell.Text & » »
     End If
Next
DateTimeToText = Left(DateTimeToText, Len(DateTimeToText) — 1)
End Function

[/vba]


skypro1111@gmail.com

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 02:03 |
Сообщение № 8

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

спасибо работает, и еще такой вопрос, можно ли объединить в макросе преобразовании даты и времени, в разных ячейках, колонках в текст, а то дата получается 0:00:00

Сообщение отредактировал romik85Пятница, 17.01.2014, 02:07

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 02:08 |
Сообщение № 9

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

Сообщение отредактировал romik85Пятница, 17.01.2014, 02:20

 

Ответить

Michael_S

Дата: Пятница, 17.01.2014, 02:17 |
Сообщение № 10

Группа: Друзья

Ранг: Старожил

Сообщений: 2012


Репутация:

373

±

Замечаний:
0% ±


Excel2016

вопрос не понятен… если преобразовывать из двух ячеек в одну — то куда? Если в третью -то зачем макрос, можно формулой… типа такой

Код

=ТЕКСТ(RC1+RC2;»ДД.ММ.ГГГГ  ч:мм:сс»)

(между ГГГГ и чч столько пробелов, сколько нужно)

Сообщение отредактировал Michael_SПятница, 17.01.2014, 02:21

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 02:20 |
Сообщение № 11

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

если преобразовывать из двух ячеек в одну — то куда?

«+» дает 1 пробел между данными, нужно 2, а лишние колонки тормозят работу( , затем файлы отдаются на загрузку

 

Ответить

Michael_S

Дата: Пятница, 17.01.2014, 02:23 |
Сообщение № 12

Группа: Друзья

Ранг: Старожил

Сообщений: 2012


Репутация:

373

±

Замечаний:
0% ±


Excel2016

…ставите между ГГГГ и чч столько пробелов, сколько нужно

 

Ответить

SkyPro

Дата: Пятница, 17.01.2014, 02:25 |
Сообщение № 13

Группа: Друзья

Ранг: Старожил

Сообщений: 1206


Репутация:

255

±

Замечаний:
0% ±


2010


эм.. а что мешает переделать?


skypro1111@gmail.com

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 02:29 |
Сообщение № 14

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

ставите между ГГГГ и чч столько пробелов, сколько нужно

ммм, не дает больше 1 пробела, результат такой же, как и =A2+B2

Сообщение отредактировал romik85Пятница, 17.01.2014, 02:30

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 02:30 |
Сообщение № 15

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013


знаний не хватает(
поэтому к вам и обратился)

Сообщение отредактировал romik85Пятница, 17.01.2014, 02:39

 

Ответить

SkyPro

Дата: Пятница, 17.01.2014, 02:44 |
Сообщение № 16

Группа: Друзья

Ранг: Старожил

Сообщений: 1206


Репутация:

255

±

Замечаний:
0% ±


2010

[vba]

Код

Sub datetext()
Dim rCell As Range, t$
For Each rCell In Selection
     t = rCell.Text
     rCell.NumberFormat = «@»
     rCell.Formula = t
Next
End Sub

[/vba]


skypro1111@gmail.com

 

Ответить

romik85

Дата: Пятница, 17.01.2014, 02:49 |
Сообщение № 17

Группа: Пользователи

Ранг: Новичок

Сообщений: 16


Репутация:

0

±

Замечаний:
20% ±


Excel 2013

SkyPro, то что надо, спасибо) ++++

тему прошу закрыть)

 

Ответить

  • Remove From My Forums
  • Question

  • I would like to convert todays date into text or a whole number representing the date.  Example: 10/11/0 into 10-11-10 or 101110.  The purpose of this is to save a workbook as todays date with one click («name101110.xlsm»).  I have
    code that works to save but needs the user to provide the date.  Is there a way to convert the date to a usable format for file saving?

    thanks in advance

Answers

  • In VBA you can create a string variable in this format using:

    Dim sDate As String

    sDate = Format(Now(), «ddmmyy»)

    Hope that helps.

    • Marked as answer by

      Monday, October 18, 2010 9:33 AM

Return to VBA Code Examples

In this Article

  • Format Function and Time
    • VBA Format Time with Predefined Formats
    • VBA Format Time with Custom Formats

This tutorial will demonstrate how to use the Format VBA function to format time.

Format Function and Time

VBA Format Time with Predefined Formats

The VBA Format function can be used to convert a number to a string with a predefined format. The available formats for time are long time, medium time, and short time.

Sub FormatTimeExample_1()
Dim DateEx As Date

DateEx = #4/18/2020 6:05:07 PM#
MsgBox Format(DateEx, "Long Time")      'Result is: 6:05:07 PM
MsgBox Format(DateEx, "Medium Time")    'Result is: 06:05 PM
MsgBox Format(DateEx, "Short Time")     'Result is: 18:05

DateEx = #2/18/2021 6:05:07 AM#
MsgBox Format(DateEx, "Long Time")      'Result is: 6:05:07 AM
MsgBox Format(DateEx, "Medium Time")    'Result is: 06:05 AM
MsgBox Format(DateEx, "Short Time")     'Result is: 06:05

End Sub

VBA Format Time with Custom Formats

The VBA Format function can be used to convert a number to a string with custom formats. Symbols h and hh are used for hours, n and nn for minutes, s and ss for seconds, ttttt for full time according to system settings and AM/PM, am/pm, A/P, a/p, AMPM for the am-pm system.

Sub FormatTimeExample_2()
Dim DateEx As Date
DateEx = #4/18/2020 6:05:07 PM#

MsgBox Format(DateEx, "hh:nn:ss")     'Result is: 18:05:07
MsgBox Format(DateEx, "h:n:s AM/PM")  'Result is: 6:5:7 PM

MsgBox Format(DateEx, "h")             'Result is: 18
MsgBox Format(DateEx, "hh")            'Result is: 18
MsgBox Format(DateEx, "h:n")           'Result is: 18:5
MsgBox Format(DateEx, "hh:nn")         'Result is: 18:05
MsgBox Format(DateEx, "hh:nn:s")       'Result is: 18:05:7
MsgBox Format(DateEx, "hh:nn:ss")      'Result is: 18:05:07

MsgBox Format(DateEx, "Time is: hh:nn:ss")
'Result is: Time is: 18:05:07
End Sub

VBA Coding Made Easy

Stop searching for VBA code online. Learn more about AutoMacro — A VBA Code Builder that allows beginners to code procedures from scratch with minimal coding knowledge and with many time-saving features for all users!
vba save as

Learn More!

Понравилась статья? Поделить с друзьями:
  • Excel vba время выполнения макроса
  • Excel vba внести данные в ячейку
  • Excel vba включить фильтр
  • Excel vba виды модулей
  • Excel vba видимость переменных