App下載

Java正則表達式的使用之去掉字符串前后的空格

猿友 2021-08-03 11:39:51 瀏覽數(shù) (3963)
反饋

相信有很多的小伙伴在學(xué)習(xí)正則表達式的時候,都會表示頭腦是嗡嗡的。因為,正則表達式中的表示符號眾多,要想全記下來恐怕得花費不少的功夫。本篇文章,我將和大家分享一個正則表達式常用的符號,用一個具體的Java編程中的問題,以及具體解決方法來為大家講解。

問題描述:

java去除字符串前后空白,身為小伙子的我搞了大半天,其實蠻簡單的。

解決方案:

方式一:

trim() trim()是 String里的常用的方法,作用:返回字符串的副本,忽略前導(dǎo)空白和尾部空白*

在這里插入圖片描述

輸出結(jié)果:

在這里插入圖片描述

方式二:正則表達式:

replaceAll(String regex,String replacement):也是String類的常用方法,

是一個形參為可以填正則表達式,第二形參為替換的內(nèi)容

這里需要的正則式:

(1) s 表示空格,

(2) ^表示開頭

(3) $表示結(jié)尾

(4) +表示數(shù)量

在這里插入圖片描述

輸出結(jié)果:

在這里插入圖片描述

完結(jié)~

補充:JAVA正則表達式匹配多個空格

需求

針對tab鍵帶來的多個空格問題,有時候我們針對帶空格的一行數(shù)據(jù)要進行切割,如果有多個空格就會出現(xiàn)就會切割空格出現(xiàn),我們想把空格都去掉,所以需要用到某些方法。

解決方案

利用正則表達式來匹配空格

\s+

首先利用split("\s+");方法來對字符串切割,盡可能的匹配空格,這里也挺有意思,因為空格數(shù)目不一樣,可以動態(tài)變換匹配的空格數(shù)量,這個實現(xiàn)原理可以看看底層原理,挺有意思。

測試:

  String string="a   b  a  a ";
  for(String a:string.split("\s+")){
   System.out.println(a);
  }

擴充知識

正則表達式的() [] {}有不同的意思。

() 是為了提取匹配的字符串。表達式中有幾個()就有幾個相應(yīng)的匹配字符串。(s*)表示連續(xù)空格的字符串。

[]是定義匹配的字符范圍。比如 [a-zA-Z0-9] 表示相應(yīng)位置的字符要匹配英文字符和數(shù)字。[s*]表示空格或者*號。

{}一般用來表示匹配的長度,比如 s{3} 表示匹配三個空格,s{1,3}表示匹配一到三個空格。

(0-9) 匹配 '0-9′ 本身。 [0-9]* 匹配數(shù)字(注意后面有 *,可以為空)[0-9]+ 匹配數(shù)字(注意后面有 +,不可以為空){1-9} 寫法錯誤。

[0-9]{0,9} 表示長度為 0 到 9 的數(shù)字字符串

()和[]有本質(zhì)的區(qū)別

()內(nèi)的內(nèi)容表示的是一個子表達式,()本身不匹配任何東西,也不限制匹配任何東西,只是把括號內(nèi)的內(nèi)容作為同一個表達式來處理,

例如:(ab){1,3},就表示ab一起連續(xù)出現(xiàn)最少1次,最多3次。如果沒有括號的話,ab{1,3},就表示a,后面緊跟的b出現(xiàn)最少1次,最多3次。另外,括號在匹配模式中也很重要。這個就不延伸了,LZ有興趣可以自己查查

[]表示匹配的字符在[]中,并且只能出現(xiàn)一次,并且特殊字符寫在[]會被當(dāng)成普通字符來匹配。例如[(a)],會匹配(、a、)、這三個字符。

所以() [] 無論是作用還是表示的含義,都有天壤之別,沒什么聯(lián)系

以上就是關(guān)于 Java 使用正則表達式去除字符串中前后空格的全部內(nèi)容,希望能給大家一個參考,也希望大家多多支持W3Cschool。如有錯誤或未考慮完全的地方,望不吝賜教!


0 人點贊