
\NewDocumentCommand\foo{>{\SplitList{;}}m}
{
\begin{table}
\begin{tabular}{ \ProcessList{#1} c}
\ProcessList{#1}{\additem}
\end{tabular}
\end{table}}
}
\newcommand\additem[1]{#1 &}
Я пытаюсь создать динамическую таблицу, которая будет принимать как можно больше аргументов из списка и выводить их в таблицу, при этом каждый элемент будет столбцом. Возникла проблема с количеством столбцов и количеством вставляемых &. Любая помощь будет высоко оценена.
Моя проблема заключается в прогнозировании количества столбцов в таблице и предотвращении
! Package array Error: Illegal pream-token (\ProcessList):
c' используется.`
или если я удалю список процессов, я получу
! Extra alignment tab has been changed to \cr.
решение1
Неясно, что будет делать эта команда, поскольку однострочная таблица представляет собой всего одну строку и поэтому tabular
вообще не нужна: вы получите требуемое поведение, просто сказав
\NewDocumentCommand{\foo}{>{\SplitList{;}}m}{%
\begin{table}
\centering
\ProcessList{#1}{\additem}
\end{table}
}
\newcommand{\additem}[1]{\mbox{\hspace{\tabcolsep}#1\hspace{\tabcolsep}}}
Полный пример с той же таблицей, набранной явно, чтобы увидеть, что вывод абсолютно тот же:
\documentclass{article}
\usepackage{xparse}
\NewDocumentCommand{\foo}{>{\SplitList{;}}m}{%
\begin{table}[htp]
\centering
\ProcessList{#1}{\additem}
\end{table}
}
\newcommand{\additem}[1]{\mbox{\hspace{\tabcolsep}#1\hspace{\tabcolsep}}}
\begin{document}
\foo{abc;def;ghijkl;m}
\begin{center}
\begin{tabular}{*{4}{c}}
abc & def & ghijkl & m
\end{tabular}
\end{center}
\end{document}
Для более полезного макроса вот способ:
\documentclass{article}
\usepackage{xparse}
\ExplSyntaxOn
\NewDocumentCommand{\foo}{m}
{
\bob_make_table:n { #1 }
}
\int_new:N \l_bob_colcount_int
\seq_new:N \l_bob_rows_seq
\seq_new:N \l_bob_temp_seq
\tl_new:N \l_bob_table_tl
\cs_new_protected:Npn \bob_make_table:n #1
{
\seq_set_split:Nnn \l_bob_rows_seq { \\ } { #1 }
\int_zero:N \l_bob_colcount_int
% count the number of columns
\seq_map_inline:Nn \l_bob_rows_seq
{
\seq_set_split:Nnn \l_bob_temp_seq { ; } { ##1 }
\int_compare:nT { \seq_count:N \l_bob_temp_seq > \l_bob_colcount_int }
{
\int_set:Nn \l_bob_colcount_int { \seq_count:N \l_bob_temp_seq }
}
}
% produce the table
\tl_set:Nn \l_bob_table_tl { \begin{tabular}{*{\l_bob_colcount_int}{c}} }
\seq_map_inline:Nn \l_bob_rows_seq
{
\seq_set_split:Nnn \l_bob_temp_seq { ; } { ##1 }
\tl_put_right:Nx \l_bob_table_tl { \seq_use:Nn \l_bob_temp_seq { & } }
\tl_put_right:Nn \l_bob_table_tl { \\ }
}
% print the table
\tl_use:N \l_bob_table_tl
\end{tabular}
}
\ExplSyntaxOff
\begin{document}
\foo{
abc;def\\
ghijkl;m;nopqrs;tu\\
vz
}
\end{document}
Строки разделяются знаком \\
, а столбцы — знаком ;
.