Utilizo los paquetes csvsimple-l3 y tabularray para generar la tabla de salida. En el código de Latex, definí que después de la tercera línea del archivo CSV de entrada, se agrega una nueva fila a la tabla. Utilicé la condición: \ifnumequal{\thecsvinputline}{3}{}{}, sin embargo, la fila agregada no aparece en la tabla de salida. ¿Por qué?
Mi código de látex:
\documentclass{article}
\begin{filecontents*}{CSVfile.csv}
a1,b,c,d
a2,b,c,d
a3,b,c,d
a4,b,c,d
a5,b,c,d
\end{filecontents*}
\usepackage{csvsimple-l3}
\usepackage{tabularray}
\usepackage{xcolor}
\usepackage{etoolbox}
\begin{document}
\csvreader[%
no head,
generic collected table= longtblr,
generic table options={[label=none]{colspec={X[1,c,m]X[1,c,m]X[1,c,m]X[1,c,m]},
row{1}={font=\bfseries},
hlines,vlines,
width=\textwidth,
colsep=2.5pt,
rowsep=2.5pt,
}},
%
late after line=\\,
late after first line=\\,
late after last line=\\,
table head={Col 1&Col 2&Col 3&Col 4}\\,
after line=\ifnumequal{\thecsvinputline}{3}{%
\\\hline\SetCell[c=4]{c}\textbf{Add a new table row}&&&\\%
}{},
]{CSVfile.csv}
{}{%
\csvcoli&\csvcolii&\csvcoliii &\csvcoliv
}
\end{document}
Así es como se ve la tabla de salida. No se agregó ninguna fila.
Si alguien puede ayudar y dar un ejemplo adecuado, será de gran utilidad. Es importante que en el ejemplo se utilicen los paquetes csvsimple-l3 y tabularray.
Respuesta1
No quiero decir que quieras hacerlo de esta manera, pero quizás puedas lograr el objetivo con el readarray
paquete:
\begin{filecontents*}{CSVfile.csv}
a1,b,c,d
a2,b,c,d
a3,b,c,d
a4,b,c,d
a5,b,c,d
\end{filecontents*}
\documentclass{article}
\usepackage{readarray}
\readarraysepchar{,}
\begin{document}
\readdef{CSVfile.csv}\mdatadat
\readarray*\mdatadat\mdata[-,\ncols]
\def\headerdat{Col1, Col2, Col3, Col4}
\readarray*\headerdat\headerrow[-,4]
\def\insertdat{\textbf{Add a new table row},x,y,z}
\readarray*\insertdat\insertrow[-,4]
\def\insertrowafter{3}
\initarray\mbefore[\insertrowafter,\ncols]
\mergearray\mdata\mbefore[1,1]
\initarray\mafter[\the\numexpr\nrows-\insertrowafter\relax,\ncols]
\mergearray\mdata\mafter[-\the\numexpr\insertrowafter-1\relax,1]
\renewcommand\typesetrowsepchar{\\\hline}
\renewcommand\typesetcolsepchar{&}
\begin{tabular}{|c|c|c|c|}
\hline
\typesetarray\headerrow\typesetrowsepchar
\typesetarray\mbefore\typesetrowsepchar
\typesetarray\insertrow\typesetrowsepchar
\typesetarray\mafter\typesetrowsepchar
\end{tabular}
\end{document}
Respuesta2
Mientras tanto, no abandoné la búsqueda de una solución. La perseverancia dio sus frutos y logré encontrar una solución que quiero mostrar y poner a disposición de quien la necesite.
\begin{filecontents*}{file0.csv}
a1,b,c,d
a2,b,c,d
a3,b,c,d
a4,b,c,d
a5,b,c,d
\end{filecontents*}
\documentclass{article}
\usepackage{csvsimple-l3}
\usepackage{tabularray}
\usepackage{xcolor}
\usepackage{ifthen}
\usepackage{readarray}
\readarraysepchar{,}
\usepackage{etoolbox}
\usepackage{array}
\begin{document}
\csvreader[%
no head,
generic collected table= longtblr,
generic table options={[label=none]{colspec=
{X[1,c,m]X[1,c,m]X[1,c,m]X[1,c,m]},
row{1}={font=\bfseries},
hlines,vlines,
width=\textwidth,
colsep=2.5pt,
rowsep=2.5pt,
}},
%
late after line=\\,
late after first line=\\,
late after last line=\\,
table head={Col 1&Col 2&Col 3&Col 4}\\,
]{file0.csv}
{}{%
\ifnumequal{\thecsvinputline}{3}{\SetCell[c=4]
{c,font=\noexpand\bfseries}Add a new table row&&&\\}{}
\csvcoli&\csvcolii&\csvcoliii &\csvcoliv}
}
\end{document}