昨天寫了一個關(guān)于Excel文件處理的腳本,在字符串匹配功能上總是出現(xiàn)多余不正確的匹配,debug調(diào)試之后,發(fā)現(xiàn)一個坑。
目前創(chuàng)新互聯(lián)建站已為1000+的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站改版維護、企業(yè)網(wǎng)站設(shè)計、寧強網(wǎng)站維護等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
------->代碼中字符串使用了replaceAll()方法,去除了所有空格(其中包括:首尾空格、中間空格)
遂整理下java關(guān)于字符串去除空格的方法。
1、方法分類
\\s* 可以匹配空格、制表符、換頁符等空白字符的其中任意一個。
2、代碼示例
package test; public class Test { /** * description:字符串去除空格的方法 */ public static void main(String[] args) { String str = " hi world ~ "; //方法1:str.trim() System.out.println("1--->"+str.trim()); //方法2:str.repalce(" ","") System.out.println("2--->"+str.replace(" ", "")); //方法3:str.repalceAll(" ","") System.out.println("3--->"+str.replaceAll(" ", "")); //方法4:str.repalceAll(" +","") System.out.println("4--->"+str.replaceAll(" +", "")); //方法5:str.repalceAll("\\s*","") System.out.println("4--->"+str.replaceAll("\\s*", "")); } }
3、輸出結(jié)果
4、replace和replaceAll是JAVA中常用的替換字符的方法,它們的區(qū)別是:
(1) replace的參數(shù)是char和CharSequence,即可以支持字符的替換,也支持字符串的替換(CharSequence即字符串序列的意思,說白了也就是字符串);
(2) replaceAll的參數(shù)是regex,即基于規(guī)則表達式的替換,比如,可以通過replaceAll("\\d", "*")把一個字符串所有的數(shù)字字符都換成星號;
相同點:都是全部替換,即把源字符串中的某一字符或字符串全部換成指定的字符或字符串,如果只想替換第一次出現(xiàn)的,可以使用
replaceFirst(),這個方法也是基于規(guī)則表達式的替換,但與replaceAll()不同的時,只替換第一次出現(xiàn)的字符串
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。