入力ファイルには可変数の列があります。出力テーブルは入力データに基づいて正しく形成されますが、データはテーブルに表示されません。Latex ファイルをコンパイルするときにエラーは発生しません。
csvsimple-l3 および tabularray パッケージは Latex コードで使用されるため、エラーを排除する新しい例でもそれらを使用することが必須です。
\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}