我正在寻找一个模式,匹配所有的东西,直到第一次出现一个特定的字符,说一个“;”-分号。

我这样写道:

/^(.*);/

但它实际上匹配所有内容(包括分号),直到最后出现一个分号。


当前回答

你需要

/^[^;]*/

[^;]是一个字符类,它匹配除分号以外的所有字符。

^ (start of line anchor)被添加到正则表达式的开头,因此只捕获每行上的第一个匹配。这可能需要,也可能不需要,这取决于是否需要可能的后续匹配。

引用perlre manpage:

您可以通过在[]中包含一个字符列表来指定一个字符类,它将匹配列表中的任何字符。如果“[”后面的第一个字符是“^”,则类匹配列表之外的任何字符。

这应该适用于大多数正则表达式方言。

其他回答

尝试/ [^;]* /

这是一个否定字符类。

你需要

/^[^;]*/

[^;]是一个字符类,它匹配除分号以外的所有字符。

^ (start of line anchor)被添加到正则表达式的开头,因此只捕获每行上的第一个匹配。这可能需要,也可能不需要,这取决于是否需要可能的后续匹配。

引用perlre manpage:

您可以通过在[]中包含一个字符列表来指定一个字符类,它将匹配列表中的任何字符。如果“[”后面的第一个字符是“^”,则类匹配列表之外的任何字符。

这应该适用于大多数正则表达式方言。

这些建议的答案对我都不起作用。(例如在notepad++中) 但

^.*?(?=\;)

did.

会;

/^(.*?);/

工作吗?

的吗?是惰性操作符,因此正则表达式在匹配;之前抓取尽可能少的内容。

我遇到了一个类似的问题,包括所有字符,直到单词entity_id后面的第一个逗号。Bigquery的解决方案是这样的:

SELECT regexp_extract(line_items,r'entity_id*[^,]*')