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