用LaTeX中的字符串替换字符

用LaTeX中的字符串替换字符,latex,Latex,我正在寻找一种在LaTeX中对字符串进行子字符串替换的方法。我想做的是构建一个命令,我可以这样调用它: \replace{File,New} 这将产生类似于 \textbf{File}$\rightarrow$\textbf{New} 这是一个简单的示例,但我希望能够将格式/结构放在单个命令中,而不是放在文档中的任何地方。我知道我可以构建几个使用越来越多参数的命令,但我希望有一种更简单的方法 编辑以进行澄清 我在找一个相当于 string.replace(",", "$\rightarrow

我正在寻找一种在LaTeX中对字符串进行子字符串替换的方法。我想做的是构建一个命令,我可以这样调用它:

\replace{File,New}
这将产生类似于

\textbf{File}$\rightarrow$\textbf{New}
这是一个简单的示例,但我希望能够将格式/结构放在单个命令中,而不是放在文档中的任何地方。我知道我可以构建几个使用越来越多参数的命令,但我希望有一种更简单的方法

编辑以进行澄清

我在找一个相当于

string.replace(",", "$\rightarrow$)
可以接受任意字符串并用另一个子字符串替换一个子字符串的内容


因此,我可以用\replace{File}、\replace{File、New}、\replace{File、Options、User}等调用该命令,用粗体格式包装单词,并用右箭头命令替换任何逗号。即使“用粗体包装”位太难(我认为可能是这样),只要更换零件就可以了。

好的,我收回这个答案。谢谢你澄清这个问题


我怀疑这可能不是你想要的,但不管怎样:

\newcommand{\replace}[2]{\textbf{#1}$\rightarrow$\textbf{#2}}  
\replace{File}{New}  

如果这不是你想要的,你能澄清一下这个问题吗?

有一个名为LaTeX的包,可以帮助你做你想做的事

这里有一个黑客(但纯乳胶,没有内部),它接近我认为你想要的,但与一些无关的空间,我还没有完全能够修复。也许可以进一步建议?与他稍微精巧的回答不同,我没有将零碎的部分参数化,如下所示:

\usepackage{forloop}  
\usepackage[trim]{tokenizer}  
...  
\newcounter{rrCount}  
\newcommand{\replace}[1]{%  
    \GetTokens{rrFirst}{rrRest}{#1,}%  
    \textbf{\rrFirst}%  
    \forloop{rrCount}{0}{\value{rrCount} < 100}{%  
        \ifthenelse{\equal{\rrRest}{}}{%  
            \setcounter{rrCount}{101}%  
        }{%  
            \GetTokens{rrFirst}{rrRest}{\rrRest}%  
            $\rightarrow$\textbf{\rrFirst}%  
        }%  
    }%  
}%  
% -----------------------------------------------------------------  
\replace{a1}\\  
\replace{a2,b2}\\  
\replace{a3,b3,c3}\\  
\usepackage{forloop}
\usepackage[trim]{tokenizer}
...  
\新计数器{rrCount}
\新命令{\replace}[1]{%
\GetTokens{rrFirst}{rrRest}{1,}%
\textbf{\rrFirst}%
\forloop{rrCount}{0}{\value{rrCount}<100}{%
\如果其他{\equal{\rrRest}{}{}{%
\设置计数器{rrCount}{101}%
}{%  
\GetTokens{rrFirst}{rrRest}{\rrRest}%
$\rightarrow$\textbf{\rrFirst}%
}%  
}%  
}%  
% -----------------------------------------------------------------  
\替换{a1}\\
\替换{a2,b2}\\
\替换{a3,b3,c3}\\

一般情况下比较棘手(当您不使用逗号作为分隔符时),但是您给出的示例可以在了解LaTeX内部结构的基础上进行编码,而不会遇到太多麻烦

\documentclass[12pt]{article}
\makeatletter
\newcommand\formatnice[1]{%
  \let\@formatsep\@formatsepinit
  \@for\@ii:=#1\do{%
    \@formatsep
    \formatentry{\@ii}%
  }%
}
\def\@formatsepinit{\let\@formatsep\formatsep}
\makeatother
\newcommand\formatsep{,}
\newcommand\formatentry[1]{#1}
\begin{document}
\formatnice{abc,def}

\renewcommand\formatsep{\,$\rightarrow$\,}
\renewcommand\formatentry[1]{\textbf{#1}}
\formatnice{abc,def}
\end{document}
请尝试以下方法:

看起来您的“空间”问题来自该软件包中的一个bug。如果用逗号包围“\GetTokens”宏,则会看到该宏插入了额外的空间

是的,标记器包中存在错误。正如我在上一篇文章中所说,错误修复是使用以下更正代码,而不仅仅是“\usepackage[trim]{tokenizer}”:


我将向开发人员报告此错误修复

Hmmm。我以前从未使用过tokenizer包;看起来您的“空间”问题来自该软件包中的一个bug。如果用逗号包围“\GetTokens”宏,则会看到该宏插入了额外的空间。因此,不是你的错:)是的,我想是的。我尝试在宏的eol中添加一些随机“%”,但没有效果。
\usepackage{xstring}

[…]

\StrSubstitute{File,New}{,}{\(\rightarrow\)}
\usepackage[trim]{tokenizer}  

\def\SH@GetTokens#1,#2\@empty{%
    \def\SH@token{#1}%
    \ifx\SH@trimtokens\SH@true% strip spaces if requested
        \TrimSpaces\SH@token%
    \fi%
    \SH@DefineCommand{\SH@FirstArgName}{\SH@token}%
    \SH@DefineCommand{\SH@SecondArgName}{#2}%
    }
\def\SH@CheckTokenSep#1,#2\@empty{%
    \def\SH@CTSArgTwo{#2}%
    \ifx\SH@CTSArgTwo\@empty%
        \edef\SH@TokenValid{\SH@false}%
    \else%
        \edef\SH@TokenValid{\SH@true}%
    \fi%
    }