輸入檔的列數是可變的。輸出表是根據輸入資料正確形成的,但資料未顯示在表中。編譯Latex檔案時沒有錯誤。
Latex 程式碼中使用了 csvsimple-l3 和 tabularray 套件,因此也要求在一些新範例中使用它們來消除錯誤。
\documentclass{article}
\begin{filecontents*}{file3.csv}
a,b,c
\end{filecontents*}
\begin{filecontents*}{file4.csv}
a,b,c,d
\end{filecontents*}
\usepackage{etoolbox}
\usepackage{csvsimple-l3}
\usepackage{tabularray}
\usepackage{xcolor}
\usepackage{ifthen}
\usepackage{readarray}
\readarraysepchar{,}
\ExplSyntaxOn
\NewExpandableDocumentCommand{\myheader}{m}{Sample & Span~over~3~or~4~columns
\prg_replicate:nn {#1} { & } Last &}
\ExplSyntaxOff
\begin{document}
\newcommand{\Disorders}[1]{%
\readdef{#1}\filedata%
\begin{tblr}[expand=\expanded]{vlines,hlines,
colspec={X[1,c,m]*{\ncols}{X[1,c,m]} X[1,c,m]X[1,c,m]},
width=\textwidth,
cell{1}{1}={r=2}{c,m,font=\small\bfseries},
cell{1}{2}={c=\ncols}{c,m,font=\small\bfseries},
cell{1}{\ncols+2}={c=2}{c,m,font=\small\bfseries},
}
\expanded{\myheader{\ncols}}
\\
\csvreader[no head]{#1}{}{
\ifnumequal{\ncols}{4}{%
&\csvcoli&\csvcolii&\csvcoliii&\csvcoliv&Result & Erros\\
}{%
\ifnumequal{\ncols}{3}{%
&\csvcoli&\csvcolii&\csvcoliii&Result & Erros
}{}%
}
}
\end{tblr}
}
\Disorders{file3.csv}
\bigskip
The file consists of \ncols{} columns.
\end{document}
有什麼錯誤嗎?如果有人知道答案並有解決方案,那將非常有幫助。
答案1
根據要求,我將軟體包限制為tabularray
和csvsimple-l3
。主要的困難是table head
。在文檔中section 3.11 Data Collection
我們可以讀到:
使用計算或不可擴展的條件可能會導致編譯錯誤。
因此測試\ifnumequal{\thecsvrow}{1}
\documentclass{article}
%https://tex.stackexchange.com/questions/706097/the-data-is-not-displayed-in-the-output-table
\usepackage{csvsimple-l3}
\usepackage{tabularray}
\usepackage{etoolbox}%<-- ifnumequal
%%%%%%%%%
\begin{filecontents*}[overwrite]{file3.csv}
a,b,c
d,e,f
g,h,i
\end{filecontents*}
\begin{filecontents*}[overwrite]{file4.csv}
a,b,c,d
\end{filecontents*}
%%%%%%%%%%
\ExplSyntaxOn
\NewExpandableDocumentCommand{\myheader}{m}{Sample & Span~over~3~or~4~columns
\prg_replicate:nn {#1} { & } Last &}
\ExplSyntaxOff
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\begin{document}
\csvreader[
no head,
tabularray =
{
vlines,hlines,
colspec={X[1,c,m] *{\thecsvcolumncount}{X[1,c,m]} X[1,c,m] X[1,c,m]},
width=\textwidth,
cell{1}{1}={r=2}{c,m,font=\small\bfseries},
cell{1}{2}={c=\thecsvcolumncount}{c,m,font=\small\bfseries},
cell{1}{\thecsvcolumncount+2}={c=2}{c,m,font=\small\bfseries},
},
% table head = Sample & Span~over~3~or~4~columns&&&\\
]{file4.csv}{}
{
\ifnumequal{\thecsvrow}{1}
{\myheader{\thecsvcolumncount}\\}
{}
\ifnumequal{\thecsvcolumncount}{4}
{%
&\csvcoli&\csvcolii&\csvcoliii&\csvcoliv&Result & Erros
}
{%
\ifnumequal{\thecsvcolumncount}{3}
{%
&\csvcoli&\csvcolii&\csvcoliii&Result & Erros
}
{}%
}
}
\bigskip
The file consists of \thecsvcolumncount{} columns.
\end{document}