grep 捕获正则表达式

发布于 2024-11-14 21:40:43 字数 242 浏览 6 评论 0原文

我正在尝试使用 grep 捕获以下数据:

"\\.xy$"
"\\.ab$"
"\\.ef\\.hi$"

我有

grep  -Eo "((\\\\\.[a-zA-Z]+)){1,2}\\$" file

两个问题:

  1. 它可以捕获 \\.xy$ 之类的内容,但不能捕获 \\.xy\\.ef$
  2. 返回的结果末尾有文字 $,为什么?

I am trying to use grep to capture data below:


"\\.xy$"
"\\.ab$"
"\\.ef\\.hi$"

I have

grep  -Eo "((\\\\\.[a-zA-Z]+)){1,2}\\$" file

two problems:

  1. It can capture things like \\.xy$, but not \\.xy\\.ef$
  2. the returned results have literal $ at the end, why?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

Hello爱情风 2024-11-21 21:40:43

在美元前面加上一个单个反斜杠:

% grep -Eo '"(\\\\\.[[:alpha:]]+){1,2}\$"' input
"\\.xy$"
"\\.ab$"
"\\.ef\\.hi$"

或者将特殊字符放入方括号中,我发现这样更容易阅读:

% grep -Eo '"([\]{2}[.][[:alpha:]]+)+"' input 
"\\.xy$"
"\\.ab$"
"\\.ef\\.hi$"

Precede the dollar with a single backslash:

% grep -Eo '"(\\\\\.[[:alpha:]]+){1,2}\$"' input
"\\.xy$"
"\\.ab$"
"\\.ef\\.hi$"

Or put the special characters into square brackets, which I find more readable:

% grep -Eo '"([\]{2}[.][[:alpha:]]+)+"' input 
"\\.xy$"
"\\.ab$"
"\\.ef\\.hi$"
黑白记忆 2024-11-21 21:40:43

你已经双重转义了 $ - 试试这个:

grep  -Eo '"((\\\\\.[a-zA-Z]+)){1,2}\$"' file

You've double-escaped the $ - try this:

grep  -Eo '"((\\\\\.[a-zA-Z]+)){1,2}\$"' file
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文