【问题标题】:Regex matches extra character正则表达式匹配额外的字符
【发布时间】:2013-12-05 14:36:59
【问题描述】:

我只想匹配“A”并排除“xyz”:

ABC xyz

但是使用

A[^xyz]

匹配

AB

编辑:我知道这个例子没有多大意义(如果我只想匹配A,我只会使用A 作为正则表达式。但它说明了我遇到的问题,无论何时我添加一个匹配模式,后跟一个[^xyz] 形式的排除模式,匹配模式似乎总是匹配一个多余的不需要的字符,(在本例中为B。)

【问题讨论】:

  • B 不是x 也不是y 也不是z[^xyz] 匹配 B。你为什么不直接使用A
  • 您可以检查使用例如:regexpal.com(对于查找正则表达式中的错误非常有用)
  • 您是否希望它匹配任何AA 后跟BCA 后跟BC xyzA 后跟@987654342 @ 或者是其他东西?请提供更多示例,说明您要提取的内容以及要从中提取的内容。

标签: regex


【解决方案1】:

A[^xyz] 匹配A*,其中* x、y 或z 中的任何字符。 有关详细信息,请参阅此页面:http://www.regular-expressions.info/charclass.html#negated

如果您想匹配任何字符串中的任何A,请使用正则表达式A。不过,我认为您正在寻找的是 A 后面没有 xyz。为此,请使用正则表达式A(?!xyz),它实现了Negative Lookahead

【讨论】:

  • 如果是这样的话,它不也匹配“ABC”吗?现在它只匹配“AB”。
  • [^xyz] 匹配不是xyz单个字符。
  • 好吧,你链接的第一页解释了它,A[^xyz] 表示 A 后跟任何不是“xyz”的字符。
【解决方案2】:

如果您只想匹配一个 A,这就是您的正则表达式应该是的。

A

您似乎想说“匹配不是 x、y 或 z 的 A”,这当然是多余的。

【讨论】:

  • 对不起,我认为这很明显,我在原帖上添加了说明。
  • 那么你想在这里匹配什么?
猜你喜欢
  • 2022-11-23
  • 2021-04-08
  • 1970-01-01
  • 2016-06-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多