Динамический заголовок (пакеты csvsimple-l3 и tabularray)

Динамический заголовок (пакеты csvsimple-l3 и tabularray)

Входной файл CSV имеет переменное количество столбцов. Данные добавляются во вторую строку во 2-й, 3-й, 4-й и 5-й столбцы. Входной файл SCV может иметь 3 или 4 столбца, поэтому данные выше будут распределены по разному количеству столбцов, что является переменной, которая изменяется в заголовке в соответствии с входным файлом CSV.

Необходимо определить динамический заголовок, который будет соответствовать входным CSV-данным.

Я создал пример кода Latex, где все адаптировано к входному CSV-файлу, кроме динамического заголовка. Моя попытка привела к ошибке, которую я не смог исправить.

Мой код Latex:

\documentclass{article}

\begin{filecontents*}{file3.csv}
 a,b,c
\end{filecontents*}

\begin{filecontents*}{file4.csv}
a,b,c,d
\end{filecontents*}

\usepackage{csvsimple-l3}
\usepackage{tabularray}
\usepackage{xcolor}
\usepackage{ifthen}
\usepackage{readarray}
\readarraysepchar{,}
\usepackage{etoolbox}

\ExplSyntaxOn
\NewExpandableDocumentCommand{\GenerateHeader}{m}
 {
  \prg_replicate:nn {#1} { & }
 }
\ExplSyntaxOff  

\begin{document}

\newcommand{\InputCSV}[1]{%
\readdef{#1}\filedata%
\csvreader[%
no head,
tabularray={colspec={X[1,c,m]
*{\ncols}{X[1,c,m]} X[1,c,m]X[1,c,m]},
hlines,vlines,
width=\textwidth,
colsep=2.5pt,
rowsep=4.5pt,
row{1-2}={c,m,fg=black,bg=black!10,font=\bfseries\small},
cell{1}{1}={r=2}{c,m,font=\small\bfseries,bg=black!10},
cell{1}{2}={c=\ncols}{c,m,font=\small\bfseries,bg=black!10},
cell{1}{\ncols+2}={c=2}{c,m,font=\small\bfseries,bg=black!10},
expand=\expanded,
},
table head=Sample&Span over 3 or 4 columns 
%&&&
\expanded{\GenerateHeader{\ncols}}
Last& \\
]{#1}
{}{%
\ifnumequal{\ncols}{4}{%
       Name  &\csvcoli&\csvcolii&\csvcoliii&\csvcoliv&Result & Erros 
                            }{%
\ifnumequal{\ncols}{3}{%
       Name  &\csvcoli&\csvcolii&\csvcoliii&Result & Erros
                            }{}%                              
                            }
  }%
}

\InputCSV{file3.csv}

\bigskip

The file consists of \ncols{} columns. 

\end{document}

Вот как должна выглядеть выходная таблица в зависимости от входного SCV-файла.

введите описание изображения здесь

введите описание изображения здесь

Если у кого-то есть идея, как решить эту проблему, и он может привести пример, это было бы очень полезно. Важно, чтобы в данном примере использовались пакеты csvsimple-l3 и tabularray.

Связанный контент