Java正則表達(dá)式匹配不到結(jié)果的解決
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 秒內(nèi)沒有輸入指令資源將被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為正則表達(dá)式
目的是匹配出<DetailInfo>標(biāo)簽中的內(nèi)容
在本地測試時(shí)可以匹配出來,但是在線上就不行。
真的是百思不得其解……
后來認(rèn)真比對了一下線上傳入的str和本地復(fù)制過來的str,發(fā)現(xiàn)了了一個(gè)微小的不同
線上傳入的str行分隔符是rn,而復(fù)制粘貼到本地之后都變成了n
而我的正則表達(dá)式中只匹配了n的情況,因此出現(xiàn)這樣的bug
提醒自己要注意系統(tǒng)之間的差別,win上的行分隔符是n,而Linux是rn
為了能適配所有的環(huán)境,可以直接用System.lineSeparator()來替代,當(dāng)然也可以把表達(dá)式寫成這樣(
<DetailInfo>((.|n|rn')*?)</DetailInfo>
補(bǔ)充:Java正則表達(dá)式匹配的坑
今天在判斷字符串是否存在某個(gè)字符串,直接用String.matches(regex),死活匹配不出來,在線正則工具用了很多都是可以的,后面找到問題,總結(jié)一下,防止再次踩坑。
一、前提#java中判斷一段字符串中是否包含某個(gè)字符串的方式:
1、#String.matches(regex);
閱讀源碼發(fā)現(xiàn),這個(gè)方法本質(zhì)是調(diào)用了Pattern.matches(regex, str),而該方法調(diào)Pattern.compile(regex).matcher(input).matches()方法,而Matcher.matches()方法試圖將整個(gè)區(qū)域與模式匹配,如果匹配成功,則可以通過開始、結(jié)束和組方法獲得更多信息。
即這個(gè)方法會(huì)在表達(dá)式前后加上$(regex$),是對這個(gè)字符串全匹配
而不會(huì)只匹配其中的子串,如果只想匹配子串,則需要表達(dá)式匹配整段
2、#Pattern.compile(regex).matcher(str).find()
Matcher.find()方法則是僅僅進(jìn)行匹配字串的方法
如果不想使用全局匹配則可以使用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);}三、總結(jié)#
各個(gè)匹配的優(yōu)缺點(diǎn)都有,大家可以按需選擇
如果僅僅只需要獲取字符串中是否包含某個(gè)字符串,還是用Matcher.find()比較方便
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. asp(vbscript)中自定義函數(shù)的默認(rèn)參數(shù)實(shí)現(xiàn)代碼2. Ajax實(shí)現(xiàn)表格中信息不刷新頁面進(jìn)行更新數(shù)據(jù)3. jsp EL表達(dá)式詳解4. jsp中sitemesh修改tagRule技術(shù)分享5. JavaWeb Servlet中url-pattern的使用6. 爬取今日頭條Ajax請求7. 如何使用瀏覽器擴(kuò)展篡改網(wǎng)頁中的JS 文件8. ASP基礎(chǔ)知識VBScript基本元素講解9. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)10. JSP servlet實(shí)現(xiàn)文件上傳下載和刪除
