Month as a two digit number

29 ビュー (過去 30 日間)
alpedhuez
alpedhuez 2020 年 7 月 2 日
コメント済み: alpedhuez 2020 年 7 月 3 日
I have
month(Date);
this will give me the number 1,2,3,...
But I want to have 01,02,03,.. as months. Please advise.
  3 件のコメント
alpedhuez
alpedhuez 2020 年 7 月 3 日
Eventually want to create yyyy-mm variable
yyyy_mm=strcat(num2str(year),'-',num2str(month));
and I want to have "month' as a two digit number so that output is like '2020-01'.
dpb
dpb 2020 年 7 月 3 日
編集済み: dpb 2020 年 7 月 3 日
Hadn't seen this comment ere now--
Again, use the proper variable class for the purpose --
>> Date = datetime('now') % build the date variable -- how is up to your application
Date =
datetime
03-Jul-2020 12:39:53
>> Date.Format='yyyy-MM' % set the desired display format--anything that uses will be as shown on output
Date =
datetime
2020-07
>> string(Date) % if you really must have a string or cellstr(), it's what you get automagically
ans =
"2020-07"
>> disp(Date) % or just use the variable; its output format is as requested
2020-07
>>
As another poster noted, do NOT use month as a variable; that aliases the builtin month() function.

サインインしてコメントする。

回答 (2 件)

Star Strider
Star Strider 2020 年 7 月 2 日
To have leading zeros, it has to be a character array or string variable.
Try this:
Date = datetime('now');
mth = sprintf('%02d',month(Date));
producing:
mth =
'07'
.
  3 件のコメント
madhan ravi
madhan ravi 2020 年 7 月 2 日
編集済み: madhan ravi 2020 年 7 月 2 日
Date = datetime('now',"Format",'MM') % which is what i mean't in my comment ;)
Star Strider
Star Strider 2020 年 7 月 3 日
I also didn’t see this Comment until now.
Expanding on my initial Answer:
Date = datetime('now')+calmonths(0:3).';
Date.Format = 'yyyy-MM';
Out = Date
produces:
Out =
4×1 datetime array
2020-07
2020-08
2020-09
2020-10
.

サインインしてコメントする。


madhan ravi
madhan ravi 2020 年 7 月 2 日
編集済み: madhan ravi 2020 年 7 月 3 日
ix = m < 10 % m is the output of the month(...) , by the way it can be set by Format in datetime(...)
M = "" + m
M(ix) = 0 + "" + m(ix)
  4 件のコメント
madhan ravi
madhan ravi 2020 年 7 月 3 日
編集済み: madhan ravi 2020 年 7 月 3 日
yyyy_mm = datetime("now","Format","uuuu-MM")
m = randi([1, 12], 10, 1); % months example
ix = m < 10 ;
M = "" + m;
M(ix) = 0 + "" + m(ix)
Note: Naming a variable month is a terrible idea!!!
alpedhuez
alpedhuez 2020 年 7 月 3 日
Let me work on it.

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeDates and Time についてさらに検索

タグ

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by