如何创建可变参数的新命令?

如何创建可变参数的新命令?

这个单词 ”可变参数的“用于可以接受任意数量的输入参数的函数和命令。


下面,我们看到一个具有三个输入的自定义命令的示例:

\newcommand{\mycmd}[3]{ {{e^{#1}}^{#2}}^{#3}}

\mycmd{1}{2}{3}   

((e^1)^2)^3 的屏幕截图

问题是,我提供少量源代码的命令始终恰好有三个输入。

我们如何创建一个允许 0 个输入、1 个输入、2 个输入、3 个输入等的可变命令?



输入数量
呼叫或调用 图片
0 \mycmd 没有指数的字母“e”的图片
1 \mycmd{1} 某物的图片
2 \mycmd{1}{2} 某物的图片
3 \mycmd{1}{2}{3} 某物的图片

答案1

下面实现了我评论中列出的参数结构,同时考虑了@Teepeemm 所做的旁注。

\documentclass{article}

\ExplSyntaxOn
\NewDocumentCommand \mycmd { O{} }
  {
    e
    \clist_map_function:nN {#1} \__idlecustard_exponent_chain:nw
    \use_none:n \__idlecustard_exponent_chain_mark:
  }
\cs_new:Npn \__idlecustard_exponent_chain:nw
    #1 #2 \__idlecustard_exponent_chain_mark:
  { \sp { #1 #2 \__idlecustard_exponent_chain_mark: } }
\ExplSyntaxOff

\begin{document}
$\mycmd$

$\mycmd[1]$

$\mycmd[1, 2]$

$\mycmd[1, 2, 3]$
\end{document}

在此处输入图片描述

答案2

网站上有数十个问题询问“带有可变数量参数的命令”。你可能去做吧,但是最好不要这么做。

诸如此类的语法\cmd[1,2,3]就简单多了。

这里有一个小小的复杂之处,你需要对每个指数进行支撑:你需要得到

e^{1^{2^{3}}}

但我们可以利用这样一个事实,即在这种情况下,\bgroup\egroup代替大括号是完全安全的。

\documentclass{article}
\usepackage{amsmath}

\ExplSyntaxOn

\NewDocumentCommand{\mycmd}{o}
 {
  e\IfValueT{#1}{\idle_exponents:n{#1}}
 }

\cs_new_protected:Nn \idle_exponents:n
 {
  \clist_map_function:nN { #1 } \__idle_exponents:n
  \prg_replicate:nn { \clist_count:n { #1 } } { \egroup }
 }
\cs_new_protected:Nn \__idle_exponents:n
 {
  ^\bgroup\scriptstyle #1
 }

\ExplSyntaxOff

\begin{document}

$\mycmd+\mycmd[1]+\mycmd[1,2]+\mycmd[1,2,3]$

\end{document}

在此处输入图片描述

仅出于学术兴趣:

\documentclass{article}
\usepackage{amsmath}

\ExplSyntaxOn

\NewDocumentCommand{\mycmd}{}
 {
  \seq_clear:N \l__idle_exponents_seq
  e\idle_exponents_gather:
 }

\seq_new:N \l__idle_exponents_seq

\cs_new_protected:Nn \idle_exponents_gather:
 {
  \peek_catcode:NTF \c_group_begin_token
   {
    \__idle_exponents_add:n
   }
   {
    \__idle_exponents_deliver:
   }
 }

\cs_new_protected:Nn \__idle_exponents_add:n
 {
  \seq_put_right:Nn \l__idle_exponents_seq { #1 }
  \idle_exponents_gather:
 }

\cs_new_protected:Nn \__idle_exponents_deliver:
 {
  \seq_map_function:NN \l__idle_exponents_seq \__idle_exponents:n
  \prg_replicate:nn { \seq_count:N \l__idle_exponents_seq } { \egroup }
 }

\cs_new_protected:Nn \__idle_exponents:n
 {
  ^\bgroup\scriptstyle #1
 }

\ExplSyntaxOff

\begin{document}

$\mycmd+\mycmd{1}+\mycmd{1}{2}+\mycmd{1}{2}{3}$

\end{document}

相关内容