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

我这样写道:

/^(.*);/

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


当前回答

"/^([^\/]*)\/$/"为我工作,从数组中只获得顶部的"文件夹":

a/   <- this
a/b/
c/   <- this
c/d/
/d/e/
f/   <- this

其他回答

你需要

/^[^;]*/

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

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

引用perlre manpage:

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

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

尝试/ [^;]* /

这是一个否定字符类。

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

^.*?(?=\;)

did.

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

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

/ ^ ^; * /

[^;]表示匹配除分号以外的任何内容。方括号是集合匹配操作符,本质上是,匹配这个字符集中的任何字符,开头的^使它成为逆匹配,所以匹配这个字符集之外的任何字符。