Как изменить макет длинной таблицы с помощью pgfplotstable

Как изменить макет длинной таблицы с помощью pgfplotstable

Для подготовки длинной серии промышленных отчетов, содержащих сложные длинные таблицы, я объединяю образцы кода, которые нашел на сайте, и это выглядит многообещающе. В моей области ячейки должны быть разделены вертикальными и горизонтальными линиями, несмотря на обычно рекомендуемые практики. В MWE (очень упрощенном по сравнению с реальной необходимостью) я все еще сталкиваюсь с двумя проблемами: нет горизонтальной линии между строками данных 1 и 2. Кроме того, я не смог разместить вертикальную линию между двумя столбцами (и другие, которые будут добавлены). Я также был бы рад любым советам по улучшению кода (мне неясно, где лучше всего выполнить форматирование столбцов и, скажем, определить горизонтальную линию между каждой строкой) и/или визуального вида. Вертикальные линии не являются непрерывными в MWE.

\documentclass[a5paper]{article}    
\usepackage{pgfplotstable}
\usepackage{longtable}
\usepackage{booktabs}
\usepackage{multirow}
\usepackage{colortbl}
\usepackage{array}
\usepackage[top=8 cm,bottom=8cm]{geometry} %For demo purposes
\usepackage{filecontents}

\begin{filecontents}{data1.csv}
column1,column2
5001,102
5002,75
5003,115
5004,45
5005,97
5036,110
5037,77
5038,147
5039,89
5040,62
5041,160
5042,102
\end{filecontents}%

\begin{document}

%%% Code from Dr. Christian Feuersanger ------ for not using headers.----------------------
\pgfkeysifdefined{/pgfplots/table/output empty row/.@cmd}{
    % upcoming releases offer this more convenient option:
    \pgfplotstableset{
        empty header/.style={
          every head row/.style={output empty row},
        }
    }
}{
    % versions up to and including 1.5.1 need this:
    \pgfplotstableset{
        empty header/.style={
            typeset cell/.append code={%
                \ifnum\pgfplotstablerow=-1 %
                    \pgfkeyssetvalue{/pgfplots/table/@cell content}{}%
                \fi
            }
        }
    }
}
%%%-----------------------------------------------


\newcommand\MyHead[2]{%
  \multicolumn{1}{|> {\centering}m{#1}|}{#2}
}

\pgfplotstabletypeset[
    empty header,
    outfile = test.dat,
    begin table=\begin{longtable},
     every first column/.style ={%
     column type/.add={|}{}
     },
         every last column/.style ={%
     column type/.add={}{|}
    },
          every head row/.style={output empty row},
    every nth row={1}{after row=\midrule},
 every first row/.append style={before row={%
    \caption{This is  a long table spreading over several pages.}%
    \label{tab:DataTable}\\\toprule
\MyHead{4cm} {column with long header} & \MyHead{4cm} {Other column with very long header}  \\ 
\hline    
    \endfirsthead
    %
    \multicolumn{2}{c}%
    {{\bfseries Table \thetable\ Continued from previous page}} \\
    \toprule 
    %
\MyHead{4cm} {column with long header} & \MyHead{4cm} {Other column with very long header}  \\ 
\hline    
    \endhead
    %
    \midrule \multicolumn{2}{r}{{Continued on next page}} \\ \bottomrule
    \endfoot
    %
    \midrule
    \multicolumn{2}{r}{{End of table}} \\ \bottomrule
    \endlastfoot
    }},%
    %
    end table=\end{longtable},
   col sep=comma,
    string type,
    ]{data1.csv}


\end{document}

решение1

Давайте начнем с простой стороны вашего вопроса(ов):

  • если хотите использовать вертикальные линии, то не используйте правила из \booktabs. Вместо них используйте\hline
  • для вертикальных линий я предлагаю сделать следующее:

    every odd column/.style ={% column type/.add={|}{} }, every even column/.style ={% column type/.add={|}{} }, every last column/.style ={% column type/.add={}{|} },

  • на мой вкус лучше сказать every nth row={1}{before row=\hline}. С этим текстом под таблицей (Продолжение на следующей странице) не имеет под ней линии.

Полный код:

\documentclass[a5paper]{article}
\usepackage{pgfplotstable}
\usepackage{longtable}
\usepackage{booktabs}
\usepackage{multirow}
\usepackage{colortbl}
\usepackage{array}
\usepackage[top=8 cm,bottom=8cm]{geometry} %For demo purposes
\usepackage{filecontents}

\begin{filecontents}{data1.csv}
column1,column2
5001,102
5002,75
5003,115
5004,45
5005,97
5036,110
5037,77
5038,147
5039,89
5040,62
5041,160
5042,102
\end{filecontents}%

\begin{document}

%%% Code from Dr. Christian Feuersanger ------ for not using headers.----------------------
\pgfkeysifdefined{/pgfplots/table/output empty row/.@cmd}{
    % upcoming releases offer this more convenient option:
    \pgfplotstableset{
        empty header/.style={
          every head row/.style={output empty row},
        }
    }
}{
    % versions up to and including 1.5.1 need this:
    \pgfplotstableset{
        empty header/.style={
            typeset cell/.append code={%
                \ifnum\pgfplotstablerow=-1 %
                    \pgfkeyssetvalue{/pgfplots/table/@cell content}{}%
                \fi
            }
        }
    }
}
%%%-----------------------------------------------
\newcommand\MyHead[2]{%
  \multicolumn{1}{|> {\centering}m{#1}|}{#2}
}    
\pgfplotstabletypeset[
    empty header,
    outfile = test.dat,
    begin table=\begin{longtable},
     every odd column/.style ={%
     column type/.add={|}{}
     },
     every even column/.style ={%
     column type/.add={|}{}
     },
         every last column/.style ={%
     column type/.add={}{|}
    },
          every head row/.style={output empty row},
    every nth row={1}{before row=\hline},
 every first row/.append style={before row={%
    \caption{This is  a long table spreading over several pages.}%
    \label{tab:DataTable}\\\hline
\MyHead{4cm} {column with long header} & \MyHead{4cm} {Other column with very long header}  \\
    \hline
    \endfirsthead
    %
    \multicolumn{2}{c}%
    {Table \thetable\ Continued from previous page} \\
    \hline
    %
\MyHead{4cm} {column with long header} & \MyHead{4cm} {Other column with very long header}  \\
    \endhead
    %
    \multicolumn{2}{r}{{Continued on next page}} \\
    \endfoot
    %
    \hline
    \multicolumn{2}{r}{{End of table}} \\ 
    \endlastfoot
    }},%
    %
    end table=\end{longtable},
   col sep=comma,
    string type,
    ]{data1.csv}
\end{document}

введите описание изображения здесь

введите описание изображения здесь

Связанный контент