如何使用 datetime2 从 \today 计算上个月?

如何使用 datetime2 从 \today 计算上个月?

是否可以使用datetime2来计算上个月\today?(或者另一个包)。

我发现了一些使用负扣除天数的解决方案,但这会在月底造成问题。

例如:\today= 2017 年 7 月 12 日

想要的输出:“今天是 2017 年 7 月 12 日。上个月是六月。”

答案1

您可以使用和保存当前日期\DTMsavenow,然后使用\DTMfetchmonthDTMmonthname或其等价物来计算上个月(或下个月)。我添加了和\lastmonth版本\nextmonth

\documentclass{article}
\usepackage[calc]{datetime2}
\usepackage{ifthen}
\newcommand\lastmonth[1]{\ifthenelse{\DTMfetchmonth{#1}=1}
    {\DTMmonthname{12}}{\DTMmonthname{\numexpr\DTMfetchmonth{#1}-1\relax}}}
\newcommand\nextmonth[1]{\ifthenelse{\DTMfetchmonth{#1}=12
    {\DTMmonthname{1}}{\DTMmonthname{\numexpr\DTMfetchmonth{#1}+1\relax}}}
\begin{document}
\DTMsavenow{today}
\DTMsavedate{jan20}{2017-01-20}
Today is \today.
Last month was \lastmonth{today}.

Today is \DTMusedate{jan20}.
Last month was \lastmonth{jan20}.

Next month is \nextmonth{jan20}.
\end{document}

代码输出

答案2

您也可以不使用任何包来执行此操作。您可以定义自己的\lastmonth宏:

在此处输入图片描述

\documentclass{article}

% \setdate{<day>}{<month>}{<year>}
\newcommand{\setdate}[3]{\day=#1\month=#2\year=#3\relax}%
\newcommand{\lastmonth}{%
  \ifcase\month\or%  0
    December\or   %  1
    January\or    %  2
    February\or   %  3
    March\or      %  4
    April\or      %  5
    May\or        %  6
    June\or       %  7
    July\or       %  8
    August\or     %  9
    September\or  % 10
    October\or    % 11
    November\fi   % 12
}

\begin{document}

Today is \today.
Last month was \lastmonth.

\setdate{20}{1}{2017}%
Today is \today.
Last month was \lastmonth.

\end{document}

相关内容