我正在尝试借助glossaries
-package 来自动化方程描述表。我已经发现这问题,但一方面它对我来说不起作用,另一方面它看起来相当复杂(与我当前的代码相比)。
这是我目前所拥有的:
\documentclass[parskip=half]{scrartcl}
\usepackage[T1]{fontenc}
\usepackage[nomain, symbols]{glossaries}
\usepackage{blindtext}
\usepackage{etoolbox}
\usepackage{multicol}
% \usepackage{showframe}
\newglossaryentry{alpha}{name={Alpha}, symbol={\ensuremath{\alpha}}, description={first symbol}}
\newglossaryentry{beta}{name={Beta}, symbol={\ensuremath{\beta}}, description={second symbol}}
\newglossaryentry{gamma}{name={Gamma}, symbol={\ensuremath{\gamma}}, description={third symbol}}
\makeglossaries
\newcommand{\addVarDesc}[1]{
\renewcommand*\do[1]{\glsadd{##1}\makebox[0.5cm][r]{\glssymbol{##1}} ${}={}$ \glsname{##1}\\}
\noindent with:\quad%
\begin{minipage}[t]{.9\linewidth}
\begin{multicols}{2}
\docsvlist{#1}
\end{multicols}
\end{minipage}\par\medskip
}
\newcommand{\addVarDescTab}[1]{
\renewcommand*\do[1]{\glsadd{##1}\glssymbol{##1} & \glsname{##1}\\}
\noindent with:\quad%
\begin{tabular}[t]{l@{${}={}$}l}
\docsvlist{#1}
\end{tabular}\par\medskip
}
\begin{document}
\printglossaries
\section{With multicols}
\blindtext[1]
\begin{equation}
\alpha = \beta + \gamma
\end{equation}
\addVarDesc{alpha, beta, gamma}
\blindtext[2]
\section{With tabular}
\blindtext[1]
\begin{equation}
\alpha = \beta + \gamma
\end{equation}
\addVarDescTab{alpha, beta, gamma}
\blindtext[2]
\end{document}
根据这些结果:
如您所见,多列变体完全放错了位置。此外,更难将条目平均对齐。但对于此版本,我喜欢列数的灵活性。
而表格版本在项目对齐方面对我来说似乎更干净。然而我在水平方向上浪费了更多空间。
您对如何改善外观有什么想法吗?我想到的一件事是将表格分成两个并排的表格。但我不知道如何使用命令来实现这一点\docsvlist
。
非常感谢您的任何想法!
答案1
我会将描述保留在显示内,以避免方程式和描述之间出现过多的空间。
另外,我们从左到右阅读(英语)。这样就可以得到
alpha gamma
beta
但我并不想这么做。
我使用 来解决它,expl3
它有许多非常方便的功能。首先,我将列表存储在可以与项目索引一起映射的序列中,这样我就可以决定是否发出\\
(在一行的末尾)或&
将项目添加到存储下一个主体的变量时tabular
。
\documentclass{article}
\usepackage[T1]{fontenc}
\usepackage[nomain, symbols]{glossaries}
\usepackage{xparse}
\usepackage{lipsum}
\newglossaryentry{alpha}{
name={Alpha},
symbol={\ensuremath{\alpha}},
description={first symbol}
}
\newglossaryentry{beta}{
name={Beta},
symbol={\ensuremath{\beta}},
description={second symbol}
}
\newglossaryentry{gamma}{
name={Gamma},
symbol={\ensuremath{\gamma}},
description={third symbol}
}
\makeglossaries
\ExplSyntaxOn
\NewDocumentCommand{\addVarDesc}{O{2}m}
{% #1 = number of columns (default 2), #2 = list of keys
\wulle_vardesc:nn { #1 } { #2 }
}
\seq_new:N \l__wulle_vardesc_vars_seq
\tl_new:N \l__wulle_vardesc_body_tl
\cs_new_protected:Nn \wulle_vardesc:nn
{
\\\notag
\begin{minipage}{\displaywidth}
\seq_set_from_clist:Nn \l__wulle_vardesc_vars_seq { #2 }
\tl_clear:N \l__wulle_vardesc_body_tl
\seq_indexed_map_inline:Nn \l__wulle_vardesc_vars_seq
{
\tl_put_right:Nn \l__wulle_vardesc_body_tl
{
\glsadd{##2}\makebox[0.5cm][r]{\glssymbol{##2}} ${}={}$ \glsname{##2}
}
\int_compare:nTF { \int_mod:nn { ##1 } { #1 } = 0 }
{
\tl_put_right:Nn \l__wulle_vardesc_body_tl { \\ }
}
{
\tl_put_right:Nn \l__wulle_vardesc_body_tl { & }
}
}
with:~\begin{tabular}[t]{@{}*{#1}{l}@{}} \l__wulle_vardesc_body_tl \end{tabular}
\end{minipage}
}
\ExplSyntaxOff
\begin{document}
\printglossaries
\lipsum[1][1-3]
\begin{gather}
\alpha = \beta + \gamma
\addVarDesc{alpha, beta, gamma}
\end{gather}
\lipsum[2][1-3]
\begin{gather}
\alpha = \beta + \gamma
\addVarDesc[3]{alpha, beta, gamma}
\end{gather}
\lipsum[3][1-3]
\begin{gather}
\alpha = \beta + \gamma
\addVarDesc[1]{alpha, beta, gamma}
\end{gather}
\lipsum[4][1-3]
\end{document}