O arquivo CSV de entrada possui um número variável de colunas. Os dados são adicionados à segunda linha na 2ª, 3ª, 4ª e 5ª colunas. O arquivo SCV de entrada pode ter 3 ou 4 colunas, portanto os dados acima ficarão espalhados por um número diferente de colunas, que é uma variável que muda no cabeçalho de acordo com o arquivo CSV de entrada.
É necessário definir um cabeçalho dinâmico que corresponda aos dados CSV de entrada.
Criei um exemplo de código Latex, onde tudo é adaptado ao arquivo CSV de entrada, exceto o cabeçalho dinâmico. Minha tentativa gerou um erro que não consegui corrigir.
Meu código látex:
\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}
Esta é a aparência da tabela de saída dependendo do arquivo SCV de entrada.
Se alguém tiver uma idéia de como resolver esse problema e puder dar um exemplo, isso seria muito útil. É importante que os pacotes csvsimple-l3 e tabularray sejam usados no exemplo dado.