国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Java正則表達式匹配不到結果的解決

瀏覽:3日期:2022-08-16 13:42:56
如下所示:

String str = 'uFEFF<?xml version='1.0' encoding='utf-8'?><Response xmlns:xsd='http://www.w3.org/2001/XMLSchema' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'><Header ShouldRecordPerformanceTime='false' Timestamp='2018-6-25 21:24:03' RequestID='2c4d0b24-fd48-4a92-a2d8-c66793df2059' ResultCode='Success' AssemblyVersion='2.9.5.0' RequestBodySize='0' SerializeMode='Xml' RouteStep='1' Environment='pro' /><SSPATResponse><Result>0</Result><FareDetail /><Price>0</Price><ErrCode>102</ErrCode><DetailInfo>Send:APPLOCKn' + 'Rev:n' + '可用資源鎖定成功, 60 秒內沒有輸入指令資源將被Buk收回n' + 'Send:IGn' + 'Rev:n' + 'NO PNRn' + 'Send:n' + 'SS:AA186/N/27JUN18/PEKORD/NN1;n' + 'Rev:n' + 'AA 186 N 27JUN PEKORD NN1 WL OPEN n' + 'UNABLE TO SELL.PLEASE CHECK THE AVAILABILITY WITH 'AV' AGAINn' + 'Send:IGn' + 'Rev:</DetailInfo><PatOfficeno>SHA717</PatOfficeno></SSPATResponse><ResponseStatus><Timestamp xmlns='http://soa.ctrip.com/common/types/v1'>2018-06-25T21:24:03.4535624+08:00</Timestamp><Ack xmlns='http://soa.ctrip.com/common/types/v1'>Success</Ack></ResponseStatus></Response>'; String regex = '<DetailInfo>((.|n')*?)</DetailInfo>';

str為要匹配的字符串(是傳入的),regex為正則表達式

目的是匹配出<DetailInfo>標簽中的內容

在本地測試時可以匹配出來,但是在線上就不行。

真的是百思不得其解……

后來認真比對了一下線上傳入的str和本地復制過來的str,發現了了一個微小的不同

線上傳入的str行分隔符是rn,而復制粘貼到本地之后都變成了n

而我的正則表達式中只匹配了n的情況,因此出現這樣的bug

提醒自己要注意系統之間的差別,win上的行分隔符是n,而Linux是rn

為了能適配所有的環境,可以直接用System.lineSeparator()來替代,當然也可以把表達式寫成這樣(

<DetailInfo>((.|n|rn')*?)</DetailInfo>

補充:Java正則表達式匹配的坑

今天在判斷字符串是否存在某個字符串,直接用String.matches(regex),死活匹配不出來,在線正則工具用了很多都是可以的,后面找到問題,總結一下,防止再次踩坑。

一、前提#

java中判斷一段字符串中是否包含某個字符串的方式:

1、#

String.matches(regex);

閱讀源碼發現,這個方法本質是調用了Pattern.matches(regex, str),而該方法調Pattern.compile(regex).matcher(input).matches()方法,而Matcher.matches()方法試圖將整個區域與模式匹配,如果匹配成功,則可以通過開始、結束和組方法獲得更多信息。

即這個方法會在表達式前后加上$(regex$),是對這個字符串全匹配

而不會只匹配其中的子串,如果只想匹配子串,則需要表達式匹配整段

2、#

Pattern.compile(regex).matcher(str).find()

Matcher.find()方法則是僅僅進行匹配字串的方法

如果不想使用全局匹配則可以使用Matcher.find()方法

二、附源碼#1、String.matches(regex)#

String.matches(regex)

public boolean matches(String regex) { return Pattern.matches(regex, this);}Pattern.matches(regex, this)

public static boolean matches(String regex, CharSequence input) { Pattern p = Pattern.compile(regex); Matcher m = p.matcher(input); return m.matches();}2、Matcher.find()#

Pattern.compile

public static Pattern compile(String regex) { return new Pattern(regex, 0);}Pattern.matcher

public Matcher matcher(CharSequence input) { if (!compiled) { synchronized(this) {if (!compiled) compile(); } } Matcher m = new Matcher(this, input); return m;}

Matcher.find()

public boolean find() { int nextSearchIndex = last; if (nextSearchIndex == first) nextSearchIndex++; // If next search starts before region, start it at region if (nextSearchIndex < from) nextSearchIndex = from; // If next search starts beyond region then it fails if (nextSearchIndex > to) { for (int i = 0; i < groups.length; i++)groups[i] = -1; return false; } return search(nextSearchIndex);}三、總結#

各個匹配的優缺點都有,大家可以按需選擇

如果僅僅只需要獲取字符串中是否包含某個字符串,還是用Matcher.find()比較方便

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Java
相關文章:
主站蜘蛛池模板: 特级毛片全部免费播放器 | 三级黄a | 武松金莲肉体交战在线观看 | 一级毛片视频免费观看 | 亚洲综合精品一二三区在线 | 久草草视频在线观看免费高清 | 日本黄大片影院一区二区 | 九九看片| 欧美成人精品动漫在线专区 | 欧美一区二区三区男人的天堂 | 国产经典一区 | 毛片免费视频网站 | 手机国产日韩高清免费看片 | 日本红怡院亚洲红怡院最新 | 91精品国产一区二区三区四区 | 久久精品a | 神马三级我不卡 | 国产成人精品在线 | 亚洲国产资源 | 99久久综合狠狠综合久久一区 | 成人国产在线不卡视频 | 欧美成人午夜影院 | 欧美人成在线视频 | 日本不卡高清免费 | 高清三级毛片 | 亚洲天堂在线视频观看 | 男女视频免费网站 | 成人a毛片 | 免费一级成人免费观看 | 欧美在线观看一区二区三区 | 国产步兵社区视频在线观看 | 精品国产一级毛片 | 国产精品一一在线观看 | 欧美成人精品一区二区 | 精品国产呦系列在线看 | 手机看片国产欧美日韩高清 | 国产美女又黄又爽又色视频免费 | 精品无码三级在线观看视频 | 成人午夜免费视频毛片 | 亚洲精品视频免费 | 亚洲乱码一二三四五六区 |