我在C#程序中具有以下正則表達式,并且難以理解它:(?<=#)[^#]+(?=#)我將其分解為我認為的理解:(?<=#) a group, matching a hash. what's `?<=`?[^#]+ one or more non-hashes (used to achieve non-greediness)(?=#) another group, matching a hash. what's the `?=`?因此,我遇到的問題是?<=and ?<部分。從閱讀MSDN開始,?<name>它用于命名組,但是在這種情況下,尖括號永遠不會關閉。我?=在文檔中找不到,搜索起來真的很困難,因為搜索引擎通常會忽略那些特殊字符。
3 回答

料青山看我應如是
TA貢獻1772條經驗 獲得超8個贊
正如另一位發帖人所述,這些是環視功能,是用于更改匹配內容和時間的特殊構造。這說:
(?<=#) match but don't capture, the string `#`
when followed by the next expression
[^#]+ one or more characters that are not `#`, and
(?=#) match but don't capture, the string `#`
when preceded by the last expression
因此,這將匹配兩個#s 之間的所有字符。
在許多情況下,先行和后退非常有用。例如,考慮規則“匹配所有b后跟一個” a。您的第一次嘗試可能類似于b[^a],但那是不對的:這也將與buin bus或boin相匹配boy,但是您只想使用in b。而且它不會匹配bin cab,即使它后面沒有一個a,因為也沒有匹配的字符了。
要正確執行此操作,您需要先行執行:b(?!a)。這表示“匹配一個,b但a之后不匹配,也不要成為匹配的一部分”。因此,它將僅匹配bin bolo,這就是您想要的;同樣,它將與bin 匹配cab。
- 3 回答
- 0 關注
- 3844 瀏覽
添加回答
舉報
0/150
提交
取消