Объединить несколько pgfplots из tex-файлов

Объединить несколько pgfplots из tex-файлов

Я использовал Sharelatex для написания своей диссертации и накопил много pgfplots. Я не могу включить более ~6 pgfplots, созданных файлами csv, прежде чем истечет время компиляции. Я разделил свои графики между несколькими файлами tex. Есть ли способ объединить все это в конечном итоге простым способом? Я попробовал поискать и, похоже, один из вариантов — конвертировать файлы pdf в png и добавлять графики как изображения, но я теряю качество и четкость рисунка (я пробовал imagemagick и был недоволен результатом). Какие у меня есть варианты, пожалуйста, посоветуйте. Спасибо.

Вот один из многих групповых графиков (в качестве примера):

\documentclass{standalone}
\usepackage[utf8]{inputenc}
\usepackage{graphicx}
\usepackage{floatrow}
\usepackage{tikz}
\usepackage{pgfplots}
\usepackage{fixltx2e}
\usepackage{siunitx}
\usepackage{lscape}
\usepackage{diagbox}
\usepackage{caption}
\usepackage{xcolor}
\usepackage[version=4]{mhchem}
\usepackage{subcaption}
\usepgfplotslibrary{groupplots}
\DeclareSIUnit{\molar}{M}
\pgfplotsset{compat=newest}



\begin{document}

\begin{figure}[h]
\setlength{\abovecaptionskip}{15pt plus 3pt minus 2pt}
\begin{minipage}{\columnwidth}
\centering
\begin{tikzpicture}[scale = .65, transform shape,trim left]    
\begin{groupplot}[
group style={
group size=2 by 3,
horizontal sep=0pt,
vertical sep=50pt
},
    scale only axis,
    xlabel={nm},
    ylabel={Abs},
    xmin=385, xmax=565, 
    xtick pos=left,
    ytick pos=left,
    no marks,
    max space between ticks=1000pt,
    try min ticks=4,
    xlabel={},
    ylabel={}
]

\nextgroupplot[title=\textbf{(a)} $15:60$ (TPPS\textsubscript{4}-\ce{2Cl}:\Lig{1})]
\addplot  table [col sep=comma, x=nm, y=10] {ST053 1560 Por SG.csv};\label{1560porsg1} 
\addplot  table [col sep=comma, x=nm, y=100] {ST053 1560 Por SG.csv};\label{1560porsg2}
\addplot  table [col sep=comma, x=nm, y=200] {ST053 1560 Por SG.csv};\label{1560porsg3}

\nextgroupplot[title=\textbf{(e)} $60:15$ (TPPS\textsubscript{4}-\ce{2Cl}:\Lig{1})]
\addplot  table [col sep=comma, x=nm, y=10] {ST053 6015 Por SG.csv};
\addplot  table [col sep=comma, x=nm, y=100] {ST053 6015 Por SG.csv};
\addplot  table [col sep=comma, x=nm, y=200] {ST053 6015 Por SG.csv};

\nextgroupplot[title=\textbf{(g)} $60:15$ (TPPS\textsubscript{4}-\ce{2Cl}:Buffer)]
\addplot table [col sep=comma, x=nm, y=10] {ST053 6015 Por blank SG.csv};
\addplot table [col sep=comma, x=nm, y=100] {ST053 6015 Por blank SG.csv};
\addplot table [col sep=comma, x=nm, y=200] {ST053 6015 Por blank SG.csv};

\end{groupplot}
\node at ($(group c1r2.west)!0.5!(group c1r2.west)$)[xshift=-1.5cm]{\rotatebox{90}{\large{Absorption}}};
\node at ($(group c1r3.south)!0.5!(group c2r3.south)$)[yshift=-1.5cm]{\large{Nanometer}};
\end{tikzpicture}
\end{minipage}
\caption{Caption}
\end{figure}

\end{document}

решение1

Я не могу это проверить.потому что я не могу скомпилировать ваш пример, так как он по сути зависит от файла, которого у меня нет. Однако вы хотите, чтобы ваш файл плана выглядел примерно так:

\documentclass[tikz]{standalone}
\usepackage[utf8]{inputenc}
\usepackage{pgfplots}
\usepackage{siunitx}
\usepackage{diagbox}
\usepackage[version=4]{mhchem}
\usepgfplotslibrary{groupplots}
\DeclareSIUnit{\molar}{M}
\pgfplotsset{compat=newest}

\begin{document}
\begin{tikzpicture}[scale = .65, transform shape, trim left]
  \begin{groupplot}[
    group style={
      group size=2 by 3,
      horizontal sep=0pt,
      vertical sep=50pt
    },
    scale only axis,
    xlabel={nm},
    ylabel={Abs},
    xmin=385, xmax=565,
    xtick pos=left,
    ytick pos=left,
    no marks,
    max space between ticks=1000pt,
    try min ticks=4,
    xlabel={},
    ylabel={}
    ]

    \nextgroupplot[title=\textbf{(a)} $15:60$ (TPPS\textsubscript{4}-\ce{2Cl}:\Lig{1})]
    \addplot  table [col sep=comma, x=nm, y=10] {ST053 1560 Por SG.csv};\label{1560porsg1}
    \addplot  table [col sep=comma, x=nm, y=100] {ST053 1560 Por SG.csv};\label{1560porsg2}
    \addplot  table [col sep=comma, x=nm, y=200] {ST053 1560 Por SG.csv};\label{1560porsg3}

    \nextgroupplot[title=\textbf{(e)} $60:15$ (TPPS\textsubscript{4}-\ce{2Cl}:\Lig{1})]
    \addplot  table [col sep=comma, x=nm, y=10] {ST053 6015 Por SG.csv};
    \addplot  table [col sep=comma, x=nm, y=100] {ST053 6015 Por SG.csv};
    \addplot  table [col sep=comma, x=nm, y=200] {ST053 6015 Por SG.csv};

    \nextgroupplot[title=\textbf{(g)} $60:15$ (TPPS\textsubscript{4}-\ce{2Cl}:Buffer)]
    \addplot table [col sep=comma, x=nm, y=10] {ST053 6015 Por blank SG.csv};
    \addplot table [col sep=comma, x=nm, y=100] {ST053 6015 Por blank SG.csv};
    \addplot table [col sep=comma, x=nm, y=200] {ST053 6015 Por blank SG.csv};

  \end{groupplot}
  \node at ($(group c1r2.west)!0.5!(group c1r2.west)$)[xshift=-1.5cm]{\rotatebox{90}{\large{Absorption}}};
  \node at ($(group c1r3.south)!0.5!(group c2r3.south)$)[yshift=-1.5cm]{\large{Nanometer}};
\end{tikzpicture}
\end{document}

Затем в основной документ вы включаете сюжет примерно такого вида:

\begin{figure}
  \centering
  \includegraphics{myfabulousplot}
  \caption{My Fabulous Plot}
  \label{fig:fabplot}
\end{figure}

Не используйте figureсреду в файле индивидуального участка .tex. Вам нужна только индивидуальная tikzpictureсреда, например.

Вы также можете сделать это автоматически. Однако, если вы пытаетесь избежать тайм-аутов, автоматический подход не является хорошей идеей.

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