Agregue una fila en la tabla de salida después de la fila especificada

Agregue una fila en la tabla de salida después de la fila especificada

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.

ingrese la descripción de la imagen aquí

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 readarraypaquete:

\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}

ingrese la descripción de la imagen aquí

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}

ingrese la descripción de la imagen aquí

información relacionada