csvsimple-l3 및 tabularray 패키지를 사용하여 출력 테이블을 생성합니다. Latex 코드에서는 입력 CSV 파일의 세 번째 줄 뒤에 테이블에 하나의 새 행이 추가되도록 정의했습니다. \ifnumequal{\thecsvinputline}{3}{}{} 조건을 사용했지만 추가된 행이 출력 테이블에 나타나지 않습니다. 왜?
내 라텍스 코드:
\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}
출력 테이블은 다음과 같습니다. 추가된 행이 없습니다.
누군가 도움을 주고 적절한 예를 제시할 수 있다면 매우 유용할 것입니다. 예제에서는 csvsimple-l3 및 tabularray 패키지를 사용하는 것이 중요합니다.
답변1
이런 식으로 하고 싶다고 말할 수는 없지만 패키지를 사용하면 목표를 달성할 수 있습니다 readarray
.
\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}
답변2
그 와중에도 나는 해결책 찾기를 포기하지 않았습니다. 끈기가 좋은 결과를 얻었고 필요한 모든 사람에게 보여주고 제공하고 싶은 솔루션을 찾을 수 있었습니다.
\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}