Separando o conteúdo antes e depois do primeiro sinal de igual

Separando o conteúdo antes e depois do primeiro sinal de igual

O método a seguir é o correto para separar o conteúdo antes e depois do primeiro sinal de igual?

\documentclass{article}

\ExplSyntaxOn

\cs_new:Npn\getbefore:w#1=#2\q_stop{#1}
\cs_new:Npn\getafter:w#1=#2\q_stop{#2}

\NewDocumentCommand\beforeafter{m}{
    \getbefore:w#1\q_stop
    \par
    \getafter:w#1\q_stop
}
\ExplSyntaxOff

\begin{document}

\beforeafter{a=2+3}

\end{document}

PS: ambas as partes serão de fato armazenadas em variáveis ​​da lista de tokens para processamento posterior.

Responder1

Esta abordagem não usa L3, mas sim o listofitemsanalisador. Peças individuais da análise mais recente podem ser obtidas via \gotten[1], \gotten[2], etc. O número total de peças é acessível via \listlen\gotten[].

\documentclass{article}
\usepackage{listofitems}
\setsepchar{=}
\newcommand\beforeafter[1]{%
  \readlist*\gotten{#1}%
  \foreachitem\z\in\gotten[]{%
    \ifnum\zcnt=1\else\par\fi
    $\z$%
  }
}
\begin{document}
\beforeafter{a=2+3}

With 3 pieces:

\beforeafter{a = 2+3 = z_1}
\end{document}

insira a descrição da imagem aqui

Responder2

Este é um método prático sem reinventar a roda:

\seq_set_split:Nnn \l_tmpa_seq { = } { #1 }
\tl_set:Ne \l_tmpa_tl { \seq_item:Nn \l_tmpa_seq { 1 } }
\tl_set:Ne \l_tmpb_tl { \seq_item:Nn \l_tmpa_seq { 2 } }

E se você tiver mais de um =token?

Você pode dividir a manutenção dos espaços e restaurar os =tokens posteriormente:

\seq_set_split_keep_spaces:Nnn \l_tmpa_seq { = } { #1 }
\seq_pop_left:NN \l_tmpa_seq \l_tmpa_tl
\tl_set:Ne \l_tmpa_tl { \tl_trim_spaces:V \l_tmpa_tl }
\tl_set:Ne \l_tmpb_tl { \seq_use:Nn \l_tmpa_seq { = } }
\tl_set:Ne \l_tmpb_tl { \tl_trim_spaces:V \l_tmpb_tl }

Os espaços ao redor dos itens à esquerda do primeiro =são cortados e os demais ao redor são cortados.

informação relacionada