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

我这样写道:

/^(.*);/

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


当前回答

这将只匹配每个字符串中的第一个出现,并忽略后续出现。

/^([^;]*);*/

其他回答

尝试/ [^;]* /

这是一个否定字符类。

这适用于从一行开始到第一个单词的内容,

/^.*?([^\s]+)/gm

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

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

这对我很有帮助,因为我试图弄清楚如何匹配xml标记中的所有字符,包括属性。我遇到了“将所有内容匹配到最后”的问题:

/<simpleChoice.*>/

但能够解决这个问题:

/<simpleChoice[^>]*>/

读完这篇文章后。谢谢所有。

尝试/ [^;]* /

谷歌正则表达式字符类的详细信息。