是否有可能优化以下ruby regexp?
%r{(.*(?:^|\s))#{pfx}\s+#([\w\-\.:/]+)\s+(.+)}.match(line)
/[^\s]\x40todo/.match(line)
/\x40todo(?!\s+#)/.match(line)
/\x40todo\s+#\s/.match(line)
/[^\s]TODO:?/.match(line)
/TODO(?!:?\s+#)/.match(line)
/TODO:?\s+#\s/.match(line)
%r{([\w\-\.]+)(?::(\d+)(?:(m|h)[a-z]*)?)?(?:/([A-Z]+))?}.match(text)实际上,我假设2-6 ->除了使用grep检查是否需要调用这个regexp#match之外没有优化的方法??
发布于 2022-03-10 07:33:30
正则表达式可以改进,但是不知道你要匹配的是什么,我不能说怎么做。但是有两个一般的优化。
Regexp.union将它们转换为单个正则表达式,如果您只想知道它是否匹配,则match?而不是match。这避免了生成MatchData对象.的开销。
https://stackoverflow.com/questions/71420131
复制相似问题