簡體   English   中英

長字符串上的Java正則表達式(String buffer)

[英]Java regex on a long string(String buffer)

我實際上有兩個問題。 第一個理論 - 如果我在StringBuffer中有一個長文本並且我想在其中找到一個正則表達式 - 我是否必須擔心StringBuffer將采用StringBuffer的塊來查找每個塊內部的正則表達式,如果它在任何塊中都沒有找到這樣的正則表達式,就好像文本里面的正則表達式不存在一樣? 如果正則表達式的一部分位於一個塊的邊界,而正則表達式的其余部分位於相鄰塊的邊界,該怎么辦?

第二:

String patternString1 = "(\\[\\[Category.*\\]\\])";
Pattern pattern1 = Pattern.compile(patternString1);
Matcher matcher1 = pattern1.matcher(text);
while (matcher1.find()){
System.out.println(matcher1.group(1));
}

我想從字符串中提取所有看起來像[[Category:。*]]的表達式,但是如果整個文本看起來像這樣:

[[類別:PrintingOut [[打印機HP]] [[HewlettPackard]] ]] [[LaserJet]]

我想確保“ ]] ”是我正則表達式的結尾。 換句話說 - 如果我在表達式中找到[[。*]],我不希望將內部[[。*]]的結尾視為整個表達式的結尾。

這可能對你有幫助。

\[\[Category:.*?\s\]\]

這是Debuggex上的演示


編輯

嘗試下面的正則表達式,如果在關閉之前有空格,將會有效]]

\[\[Category:.*?[(\]\])\s]+\]\]

這是Debuggex上的演示

注意:只需將此正則表達式模式包含在() ,然后在索引1處獲取該組。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM