我正在寻找一个模式,匹配所有的东西,直到第一次出现一个特定的字符,说一个“;”-分号。
我这样写道:
/^(.*);/
但它实际上匹配所有内容(包括分号),直到最后出现一个分号。
我正在寻找一个模式,匹配所有的东西,直到第一次出现一个特定的字符,说一个“;”-分号。
我这样写道:
/^(.*);/
但它实际上匹配所有内容(包括分号),直到最后出现一个分号。
当前回答
我遇到了一个类似的问题,包括所有字符,直到单词entity_id后面的第一个逗号。Bigquery的解决方案是这样的:
SELECT regexp_extract(line_items,r'entity_id*[^,]*')
其他回答
真的有点难过,没有人给你正确的答案....
在正则表达式中,?使它非贪婪。默认情况下,regex将尽可能多地匹配(贪婪)
简单地加一个?并且它将是非贪婪的,匹配越少越好!
祝你好运,希望有帮助。
尝试/ [^;]* /
谷歌正则表达式字符类的详细信息。
/ ^ ^; * /
[^;]表示匹配除分号以外的任何内容。方括号是集合匹配操作符,本质上是,匹配这个字符集中的任何字符,开头的^使它成为逆匹配,所以匹配这个字符集之外的任何字符。
这适用于从一行开始到第一个单词的内容,
/^.*?([^\s]+)/gm
尝试/ [^;]* /
这是一个否定字符类。