按字元拆分字串並與格式合併

按字元拆分字串並與格式合併

我怎麼才能建立宏

\split{ABC}

輸出

在此輸入影像描述

其中字元的格式是用另一個巨集進行的,即

\formatchar{A}

在哪裡

\def\formatchar#1{{\color{red}#1}}

對於任何字串長度?

我嘗試修改中的程式碼 將字串 n 分割為 n

\documentclass{article}
\usepackage{xstring}

\def\split#1#2{%
    \StrSplit{#2}{1}\tempa\tempb
    x%
    \tempa\let\tempa\empty
    \unless\ifx\tempb\empty\def\tempa{|\split{1}\tempb}\fi
    y%
    \tempa
}

\begin{document}
\split{1}{ABCD}
\end{document}

我在之前和之後得到了 x 和 y (因為我無法使用命令和 } 進行限制),但我無法正確格式化它。另外我想避免調用中的 {1} ,並使用

\split{ABCD}

僅有的。它始終是 1 個字元的分割。

任何幫助深表感謝!

答案1

如果您的輸入不能保證是“僅 ASCII”,則方法\seq_set_split:Nnn可能不起作用。

我把名字改成了\splitchars因為\split被佔用了amsmath

\documentclass{article}
\usepackage[T1]{fontenc}
\usepackage{xcolor}

\NewDocumentCommand{\formatchar}{m}{%
  \textcolor{red!90!yellow}{#1}% <--- or whatever you like
}

\ExplSyntaxOn

\NewDocumentCommand{\splitchars}{O{|}m}
 {% #1 = optional separator, default |
  % #2 = text to split
  \mflxvii_split:nn { #1 } { #2 }
 }

\seq_new:N \l__mflxvii_split_items_seq

\cs_new_protected:Nn \mflxvii_split:nn
 {
  \seq_clear:N \l__mflxvii_split_items_seq
  \text_map_inline:nn { #2 }
   {
    \seq_put_right:Nn \l__mflxvii_split_items_seq { \formatchar{##1} }
   }
  \seq_use:Nn \l__mflxvii_split_items_seq { #1 }
 }

\ExplSyntaxOff

\begin{document}

\splitchars{ABC}

\splitchars[--]{ABC}

\splitchars{ábç}

\splitchars{ÅÄÖ}

\end{document}

在此輸入影像描述

為了獲得類似列表的輸出,這裡有一個擴展,允許最後兩項之間使用不同的分隔符號。

\documentclass{article}
\usepackage[T1]{fontenc}
\usepackage{xcolor}

\NewDocumentCommand{\formatchar}{m}{%
  \textcolor{red!90!yellow}{#1}% <--- or whatever you like
}

\ExplSyntaxOn

\NewDocumentCommand{\splitchars}{O{|}O{#1}m}
 {% #1 = optional separator, default |
  % #2 = optional separator between last two
  % #3 = text to split
  \mflxvii_split:nnn { #1 } { #2 } { #3 }
 }

\seq_new:N \l__mflxvii_split_items_seq

\cs_new_protected:Nn \mflxvii_split:nnn
 {
  \seq_clear:N \l__mflxvii_split_items_seq
  \text_map_inline:nn { #3 }
   {
    \seq_put_right:Nn \l__mflxvii_split_items_seq { \formatchar{##1} }
   }
  \seq_use:Nnnn \l__mflxvii_split_items_seq { #2 } { #1 } { #2 }
 }

\ExplSyntaxOff

\begin{document}

\splitchars{ABC}

\splitchars[--]{ABC}

\splitchars{ábç}

\splitchars{ÅÄÖ}

\splitchars[, ][ and ]{ÅÄÖ}

\splitchars[, ][ and ]{ÅÄ}

\end{document}

在此輸入影像描述

答案2

這是一個基於 LuaLaTeX 的解決方案,它利用了 Luagsubsub內建函數。實際上,該程式碼使用了可以直接處理 utf8 編碼字元的gsub和函數版本。sub

主要的用戶級巨集被稱為\splitstring而不是\split,因為阿姆斯數學套件定義了一個名為 的環境split以及名為\split和 的巨集\endsplit

觀察到 (a) 的參數\splitstring可以包含空格,並且 (b)formatchar是作為 Lua 函數而不是 LaTeX 巨集實現的。

在此輸入影像描述

% !TEX TS-program = lualatex
\documentclass{article}
\usepackage{xcolor}  % for '\textcolor' macro

% Lua-side code
\directlua{
  function formatchar ( c )
     return ( '\\textcolor{red}{\\textbf{' .. c .. '}}|' )
  end
  function split ( s )
     s = unicode.utf8.gsub ( s , '.' , formatchar )
     return ( unicode.utf8.sub ( s , 1 , -2 ) ) % delete final '|'
  end
}
% LaTeX-side code
\newcommand\splitstring[1]{\directlua{tex.sprint(split('#1'))}}

\begin{document}
\obeylines % just for this example
\splitstring{ABC}
\splitstring{123abc}
\splitstring{Hello World}
\end{document}

答案3

這是我使用 ExplSyntax 的解決方案嘗試:

\documentclass{article}
\usepackage{xcolor}

\ExplSyntaxOn
\seq_new:N \l__my_split_seq
\NewDocumentCommand { \split } { m } {  \__my_split:n { #1 }  }
\cs_new_protected:Npn \__my_split:n #1
{
  \seq_set_split:Nnn \l__my_split_seq {} { #1 }
  \seq_set_map:NNn \l__my_split_seq \l__my_split_seq
  {  \__my_split_fn:n { ##1 }  }
  % \seq_log:N \l__my_split_seq
  \seq_use:Nn \l__my_split_seq { | }
}
\cs_new_protected:Npn \__my_split_fn:n #1 {   {  \color { red } #1  }   }
\ExplSyntaxOff

\begin{document}

\split{ABCD}

\split{1234}

\end{document}

在此輸入影像描述

答案4

由於沒有提供 LaTeX2e 解決方案,我在這裡提供一個。我使用令牌循環從參數中一一抓取字元。此解決方案假設參數沒有宏,也沒有組。我省略了這些,因為沒有給出如何處理它們的指導,儘管可以根據需要處理它們。

如果需要處理unicode字符,必須在xelatex或lualatex下進行編譯。

\documentclass{article}
\usepackage{tokcycle,xcolor}
\newcommand\formatchar[1]{\textcolor{red}{#1}}
\def\split#1{%
  \tokencycle{\formatchar{##1}\splitchar}
  {}{}{##1\splitchar}#1\endtokencycle}
\newcommand\splitchar{\tcpeek\z\ifx\empty\z\else$\mid$\fi}
\begin{document}
\split{ABCD}

\split{Å ÄÖ}
\end{document}

在此輸入影像描述

相關內容