摘要:
閱讀全文
摘要:
閱讀全文
StringUtils 方法的操作對(duì)象是 java.lang.String 類型的對(duì)象,是 JDK 提供的 String 類型操作方法的補(bǔ)充,并且是 null 安全的(即如果輸入?yún)?shù) String 為 null 則不會(huì)拋出 NullPointerException ,而是做了相應(yīng)處理,例如,如果輸入為 null 則返回也是 null 等,具體可以查看源代碼)。
除了構(gòu)造器,StringUtils 中一共有130多個(gè)方法,并且都是 static 的,所以我們可以這樣調(diào)用 StringUtils.xxx()
下面分別對(duì)一些常用方法做簡(jiǎn)要介紹:
1. public static boolean isEmpty(String str)
判斷某字符串是否為空,為空的標(biāo)準(zhǔn)是 str==null 或 str.length()==0
下面是 StringUtils 判斷是否為空的示例:
StringUtils.isEmpty(null) = true
StringUtils.isEmpty("") = true
StringUtils.isEmpty(" ") = false //注意在 StringUtils 中空格作非空處理
StringUtils.isEmpty(" ") = false
StringUtils.isEmpty("bob") = false
StringUtils.isEmpty(" bob ") = false
2. public static boolean isNotEmpty(String str)
判斷某字符串是否非空,等于 !isEmpty(String str)
下面是示例:
StringUtils.isNotEmpty(null) = false
StringUtils.isNotEmpty("") = false
StringUtils.isNotEmpty(" ") = true
StringUtils.isNotEmpty(" ") = true
StringUtils.isNotEmpty("bob") = true
StringUtils.isNotEmpty(" bob ") = true
3. public static boolean isBlank(String str)
判斷某字符串是否為空或長(zhǎng)度為0或由空白符(whitespace) 構(gòu)成
下面是示例:
StringUtils.isBlank(null) = true
StringUtils.isBlank("") = true
StringUtils.isBlank(" ") = true
StringUtils.isBlank(" ") = true
StringUtils.isBlank("\t \n \f \r") = true //對(duì)于制表符、換行符、換頁(yè)符和回車符
StringUtils.isBlank() //均識(shí)為空白符
StringUtils.isBlank("\b") = false //"\b"為單詞邊界符
StringUtils.isBlank("bob") = false
StringUtils.isBlank(" bob ") = false
4. public static boolean isNotBlank(String str)
判斷某字符串是否不為空且長(zhǎng)度不為0且不由空白符(whitespace) 構(gòu)成,等于 !isBlank(String str)
下面是示例:
StringUtils.isNotBlank(null) = false
StringUtils.isNotBlank("") = false
StringUtils.isNotBlank(" ") = false
StringUtils.isNotBlank(" ") = false
StringUtils.isNotBlank("\t \n \f \r") = false
StringUtils.isNotBlank("\b") = true
StringUtils.isNotBlank("bob") = true
StringUtils.isNotBlank(" bob ") = true
5. public static String trim(String str)
去掉字符串兩端的控制符(control characters, char <= 32) , 如果輸入為 null 則返回null
下面是示例:
StringUtils.trim(null) = null
StringUtils.trim("") = ""
StringUtils.trim(" ") = ""
StringUtils.trim(" \b \t \n \f \r ") = ""
StringUtils.trim(" \n\tss \b") = "ss"
StringUtils.trim(" d d dd ") = "d d dd"
StringUtils.trim("dd ") = "dd"
StringUtils.trim(" dd ") = "dd"
6. public static String trimToNull(String str)
去掉字符串兩端的控制符(control characters, char <= 32) ,如果變?yōu)?null 或"",則返回 null
下面是示例:
StringUtils.trimToNull(null) = null
StringUtils.trimToNull("") = null
StringUtils.trimToNull(" ") = null
StringUtils.trimToNull(" \b \t \n \f \r ") = null
StringUtils.trimToNull(" \n\tss \b") = "ss"
StringUtils.trimToNull(" d d dd ") = "d d dd"
StringUtils.trimToNull("dd ") = "dd"
StringUtils.trimToNull(" dd ") = "dd"
7. public static String trimToEmpty(String str)
去掉字符串兩端的控制符(control characters, char <= 32) ,如果變?yōu)?null 或 "" ,則返回 ""
下面是示例:
StringUtils.trimToEmpty(null) = ""
StringUtils.trimToEmpty("") = ""
StringUtils.trimToEmpty(" ") = ""
StringUtils.trimToEmpty(" \b \t \n \f \r ") = ""
StringUtils.trimToEmpty(" \n\tss \b") = "ss"
StringUtils.trimToEmpty(" d d dd ") = "d d dd"
StringUtils.trimToEmpty("dd ") = "dd"
StringUtils.trimToEmpty(" dd ") = "dd"
8. public static String strip(String str)
去掉字符串兩端的空白符(whitespace) ,如果輸入為 null 則返回 null
下面是示例(注意和 trim() 的區(qū)別):
StringUtils.strip(null) = null
StringUtils.strip("") = ""
StringUtils.strip(" ") = ""
StringUtils.strip(" \b \t \n \f \r ") = "\b"
StringUtils.strip(" \n\tss \b") = "ss \b"
StringUtils.strip(" d d dd ") = "d d dd"
StringUtils.strip("dd ") = "dd"
StringUtils.strip(" dd ") = "dd"
9. public static String stripToNull(String str)
去掉字符串兩端的空白符(whitespace) ,如果變?yōu)?null 或"",則返回 null
下面是示例(注意和 trimToNull() 的區(qū)別):
StringUtils.stripToNull(null) = null
StringUtils.stripToNull("") = null
StringUtils.stripToNull(" ") = null
StringUtils.stripToNull(" \b \t \n \f \r ") = "\b"
StringUtils.stripToNull(" \n\tss \b") = "ss \b"
StringUtils.stripToNull(" d d dd ") = "d d dd"
StringUtils.stripToNull("dd ") = "dd"
StringUtils.stripToNull(" dd ") = "dd"
10. public static String stripToEmpty(String str)
去掉字符串兩端的空白符(whitespace) ,如果變?yōu)?span style="font-family: verdana,geneva"> null 或"" ,則返回""
下面是示例(注意和 trimToEmpty() 的區(qū)別):
StringUtils.stripToNull(null) = ""
StringUtils.stripToNull("") = ""
StringUtils.stripToNull(" ") = ""
StringUtils.stripToNull(" \b \t \n \f \r ") = "\b"
StringUtils.stripToNull(" \n\tss \b") = "ss \b"
StringUtils.stripToNull(" d d dd ") = "d d dd"
StringUtils.stripToNull("dd ") = "dd"
StringUtils.stripToNull(" dd ") = "dd"
以下方法只介紹其功能,不再舉例:
11. public static String strip(String str, String stripChars)
去掉 str 兩端的在 stripChars 中的字符。
如果 str 為 null 或等于"" ,則返回它本身;
如果 stripChars 為 null 或"" ,則返回 strip(String str) 。
12. public static String stripStart(String str, String stripChars)
和11相似,去掉 str 前端的在 stripChars 中的字符。
13. public static String stripEnd(String str, String stripChars)
和11相似,去掉 str 末端的在 stripChars 中的字符。
14. public static String[] stripAll(String[] strs)
對(duì)字符串?dāng)?shù)組中的每個(gè)字符串進(jìn)行 strip(String str) ,然后返回。
如果 strs 為 null 或 strs 長(zhǎng)度為0,則返回 strs 本身
15. public static String[] stripAll(String[] strs, String stripChars)
對(duì)字符串?dāng)?shù)組中的每個(gè)字符串進(jìn)行 strip(String str, String stripChars) ,然后返回。
如果 strs 為 null 或 strs 長(zhǎng)度為0,則返回 strs 本身
16. public static boolean equals(String str1, String str2)
比較兩個(gè)字符串是否相等,如果兩個(gè)均為空則也認(rèn)為相等。
17. public static boolean equalsIgnoreCase(String str1, String str2)
比較兩個(gè)字符串是否相等,不區(qū)分大小寫(xiě),如果兩個(gè)均為空則也認(rèn)為相等。
18. public static int indexOf(String str, char searchChar)
返回字符 searchChar 在字符串 str 中第一次出現(xiàn)的位置。
如果 searchChar 沒(méi)有在 str 中出現(xiàn)則返回-1,
如果 str 為 null 或 "" ,則也返回-1
19. public static int indexOf(String str, char searchChar, int startPos)
返回字符 searchChar 從 startPos 開(kāi)始在字符串 str 中第一次出現(xiàn)的位置。
如果從 startPos 開(kāi)始 searchChar 沒(méi)有在 str 中出現(xiàn)則返回-1,
如果 str 為 null 或 "" ,則也返回-1
20. public static int indexOf(String str, String searchStr)
返回字符串 searchStr 在字符串 str 中第一次出現(xiàn)的位置。
如果 str 為 null 或 searchStr 為 null 則返回-1,
如果 searchStr 為 "" ,且 str 為不為 null ,則返回0,
如果 searchStr 不在 str 中,則返回-1
21. public static int ordinalIndexOf(String str, String searchStr, int ordinal)
返回字符串 searchStr 在字符串 str 中第 ordinal 次出現(xiàn)的位置。
如果 str=null 或 searchStr=null 或 ordinal<=0 則返回-1
舉例(*代表任意字符串):
StringUtils.ordinalIndexOf(null, *, *) = -1
StringUtils.ordinalIndexOf(*, null, *) = -1
StringUtils.ordinalIndexOf("", "", *) = 0
StringUtils.ordinalIndexOf("aabaabaa", "a", 1) = 0
StringUtils.ordinalIndexOf("aabaabaa", "a", 2) = 1
StringUtils.ordinalIndexOf("aabaabaa", "b", 1) = 2
StringUtils.ordinalIndexOf("aabaabaa", "b", 2) = 5
StringUtils.ordinalIndexOf("aabaabaa", "ab", 1) = 1
StringUtils.ordinalIndexOf("aabaabaa", "ab", 2) = 4
StringUtils.ordinalIndexOf("aabaabaa", "bc", 1) = -1
StringUtils.ordinalIndexOf("aabaabaa", "", 1) = 0
StringUtils.ordinalIndexOf("aabaabaa", "", 2) = 0
22. public static int indexOf(String str, String searchStr, int startPos)
返回字符串 searchStr 從 startPos 開(kāi)始在字符串 str 中第一次出現(xiàn)的位置。
舉例(*代表任意字符串):
StringUtils.indexOf(null, *, *) = -1
StringUtils.indexOf(*, null, *) = -1
StringUtils.indexOf("", "", 0) = 0
StringUtils.indexOf("aabaabaa", "a", 0) = 0
StringUtils.indexOf("aabaabaa", "b", 0) = 2
StringUtils.indexOf("aabaabaa", "ab", 0) = 1
StringUtils.indexOf("aabaabaa", "b", 3) = 5
StringUtils.indexOf("aabaabaa", "b", 9) = -1
StringUtils.indexOf("aabaabaa", "b", -1) = 2
StringUtils.indexOf("aabaabaa", "", 2) = 2
StringUtils.indexOf("abc", "", 9) = 3
23. public static int lastIndexOf(String str, char searchChar)
基本原理同18
24. public static int lastIndexOf(String str, char searchChar, int startPos)
基本原理同19
25. public static int lastIndexOf(String str, String searchStr)
基本原理同20
26. public static int lastIndexOf(String str, String searchStr, int startPos)
基本原理同22
另附:
String 的 split(String regex) 方法的用法
如果我們需要把某個(gè)字符串拆分為字符串?dāng)?shù)組,則通常用 split(String regex) 來(lái)實(shí)現(xiàn)。
例如:
- String str = "aa,bb,cc,dd";
- String[] strArray = str.split(",");
- System.out.println(strArray.length);
- for (int i = 0; i < strArray.length; i++) {
- System.out.println(strArray[i]);
- }
String str = "aa,bb,cc,dd";
String[] strArray = str.split(",");
System.out.println(strArray.length);
for (int i = 0; i < strArray.length; i++) {
System.out.println(strArray[i]);
}
結(jié)果為:
4
aa
bb
cc
dd
如果,
String str = "aa.bb.cc.dd";
String[] strArray = str.split(".");
則結(jié)果為:0
為什么結(jié)果不是我們所想的呢,原因是參數(shù) String regex 是正則表達(dá)式 (regular expression) 而不是普通字符串,而 "." 在正則表達(dá)式中有特殊含義,表示匹配所有單個(gè)字符。如果要那樣拆分,我們必須給 "." 進(jìn)行轉(zhuǎn)義,String[] strArray = str.split(".") 修改為 String[] strArray = str.split("\\.") 即可。
另外有關(guān) StringUtils 的詳細(xì) API 請(qǐng)參見(jiàn)官方網(wǎng)站: http://commons.apache.org/lang/api/org/apache/commons/lang/StringUtils.html
所有標(biāo)簽:
Tags
fmt:requestEncoding
fmt:setLocale
fmt:timeZone
fmt:setTimeZone
fmt:bundle
fmt:setBundle
fmt:message
fmt:param
fmt:formatNumber
fmt:parseNumber
fmt:formatDate
fmt:parseDate
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
jstl fmt 函數(shù)大全
主要功能格式化
日期格式(2008年5月5日22點(diǎn)00分23秒)
<fmt:formatDate value="<%=new Date() %>" pattern="yyyy年MM月dd日HH點(diǎn)mm分ss秒" />
保留兩位小數(shù)
<fmt:formatNumber value="123.123456789" pattern="0.00"/>
格式數(shù)字(45,678.234)
<fmt:formatNumber type="number" value="45678.2345" />
格式百分比(23%)
<fmt:formatNumber type="percent" value="0.2345" />
其他
<fmt:bundle>:資源綁定。除了以前提到過(guò)的在web.xml中聲明以外,還可以利用此標(biāo)簽。
例<fmt:bundle basename="message"></fmt:bundle>
<fmt:setLocale>:設(shè)置locale,主要是用于這種情況,一個(gè)中國(guó)人在國(guó)外,locale是en_US,但想用中文顯示。
例:<fmt:setLocal value="zh_CN"/>
<fmt:message>:輸出properties文件中的指定內(nèi)容。
例<fmt:message key="user"/>
<fmt:formatNumber type="number">格式化普通數(shù)字
<fmt:formatNumber type="percent">格式化百分比
三種數(shù)字類型參數(shù):currency,number,percent
<fmt:parseNumber var="i" type="number" value="45678.2345" />
<c:out value="${i}" escapeXml="false" /> 分析出數(shù)字
<fmt:requestEncoding value="GB18030"/> 格式化文本編碼
<fmt:formatDate value="${date}" type="both" timeStyle="long" dateStyle="long" />
type="both" 輸入日期也同時(shí)輸出具體時(shí)間
timeStyle="long" 時(shí)間以“長(zhǎng)”格式輸出 差別:下午02時(shí)06分59秒 與 14:06:59
dateStyle="long" 日期以“長(zhǎng)”格式輸出 差別:2006年9月7日 與 2006-9-7
四種長(zhǎng)短參數(shù):long,short,medium,full
<fmt:timeZone value="${timezone}"/> 時(shí)區(qū)偏移,與上面可配合使用:
<fmt:formatDate value="$rdxotvm" timeZone="${zn}" type="both" />
<fmt:parseDate var="i" type="date" value="2006-12-11" />
<c:out value="${i}" escapeXml="false" /> 分析出時(shí)間
JSTL使用表達(dá)式來(lái)簡(jiǎn)化頁(yè)面的代碼,這對(duì)一些標(biāo)準(zhǔn)的方法,例如bean的getter/setter方法,請(qǐng)求參數(shù)或者context以及session中的數(shù)據(jù)的訪問(wèn)非常方便,但是我們?cè)趯?shí)際應(yīng)用中經(jīng)常需要在頁(yè)面調(diào)用對(duì)象的某些方法,例如我需要調(diào)用字符串的length方法來(lái)獲取字符串的長(zhǎng)度時(shí),在以往的開(kāi)發(fā)過(guò)程中我們必須把對(duì)象先轉(zhuǎn)為String類,然后在調(diào)用其length方法,這樣的代碼繁瑣而且容易出錯(cuò)。
因此JSTL內(nèi)置了幾個(gè)用于字符串操作的方法,可以直接在表達(dá)式中使用,大大的簡(jiǎn)化了代碼,提供代碼的可讀性。在JSTL的表達(dá)是中要使用一個(gè)函數(shù),其格式如下
${ns:methodName(args....)}
在使用這些函數(shù)之前必須在JSP中引入標(biāo)準(zhǔn)函數(shù)的聲明
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
下面是JSTL中自帶的方法列表以及其描述
函數(shù)名 |
函數(shù)說(shuō)明 |
使用舉例 |
fn:contains |
判斷字符串是否包含另外一個(gè)字符串 |
<c:if test="${fn:contains(name, searchString)}"> |
fn:containsIgnoreCase |
判斷字符串是否包含另外一個(gè)字符串(大小寫(xiě)無(wú)關(guān)) |
<c:if test="${fn:containsIgnoreCase(name, searchString)}"> |
fn:endsWith |
判斷字符串是否以另外字符串結(jié)束 |
<c:if test="${fn:endsWith(filename, ".txt")}"> |
fn:escapeXml |
把一些字符轉(zhuǎn)成XML表示,例如<字符應(yīng)該轉(zhuǎn)為< |
${fn:escapeXml(param:info)} |
fn:indexOf |
子字符串在母字符串中出現(xiàn)的位置 |
${fn:indexOf(name, "-")} |
fn:join |
將數(shù)組中的數(shù)據(jù)聯(lián)合成一個(gè)新字符串,并使用指定字符格開(kāi) |
${fn:join(array, ";")} |
fn:length |
獲取字符串的長(zhǎng)度,或者數(shù)組的大小 |
${fn:length(shoppingCart.products)} |
fn:replace |
替換字符串中指定的字符 |
${fn:replace(text, "-", "")} |
fn:split |
把字符串按照指定字符切分 |
${fn:split(customerNames, ";")} |
fn:startsWith |
判斷字符串是否以某個(gè)子串開(kāi)始 |
<c:if test="${fn:startsWith(product.id, "100-")}"> |
fn:substring |
獲取子串 |
${fn:substring(zip, 6, -1)} |
fn:substringAfter |
獲取從某個(gè)字符所在位置開(kāi)始的子串
|
${fn:substringAfter(zip, "-")} |
fn:substringBefore |
獲取從開(kāi)始到某個(gè)字符所在位置的子串 |
${fn:substringBefore(zip, "-")} |
fn:toLowerCase |
轉(zhuǎn)為小寫(xiě) |
${fn.toLowerCase(product.name)} |
fn:toUpperCase |
轉(zhuǎn)為大寫(xiě)字符 |
${fn.UpperCase(product.name)} |
fn:trim |
去除字符串前后的空格 |
${fn.trim(name)} |
函數(shù)
|
描述
|
fn:contains(string, substring)
|
如果參數(shù)string中包含參數(shù)substring,返回true
|
fn:containsIgnoreCase(string, substring)
|
如果參數(shù)string中包含參數(shù)substring(忽略大小寫(xiě)),返回true
|
fn:endsWith(string, suffix)
|
如果參數(shù) string 以參數(shù)suffix結(jié)尾,返回true
|
fn:escapeXml(string)
|
將有特殊意義的XML (和HTML)轉(zhuǎn)換為對(duì)應(yīng)的XML character entity code,并返回
|
fn:indexOf(string, substring)
|
返回參數(shù)substring在參數(shù)string中第一次出現(xiàn)的位置
|
fn:join(array, separator)
|
將一個(gè)給定的數(shù)組array用給定的間隔符separator串在一起,組成一個(gè)新的字符串并返回。
|
fn:length(item)
|
返回參數(shù)item中包含元素的數(shù)量。參數(shù)Item類型是數(shù)組、collection或者String。如果是String類型,返回值是String中的字符數(shù)。
|
fn:replace(string, before, after)
|
返回一個(gè)String對(duì)象。用參數(shù)after字符串替換參數(shù)string中所有出現(xiàn)參數(shù)before字符串的地方,并返回替換后的結(jié)果
|
fn:split(string, separator)
|
返回一個(gè)數(shù)組,以參數(shù)separator 為分割符分割參數(shù)string,分割后的每一部分就是數(shù)組的一個(gè)元素
|
fn:startsWith(string, prefix)
|
如果參數(shù)string以參數(shù)prefix開(kāi)頭,返回true
|
fn:substring(string, begin, end)
|
返回參數(shù)string部分字符串, 從參數(shù)begin開(kāi)始到參數(shù)end位置,包括end位置的字符
|
fn:substringAfter(string, substring)
|
返回參數(shù)substring在參數(shù)string中后面的那一部分字符串
|
fn:substringBefore(string, substring)
|
返回參數(shù)substring在參數(shù)string中前面的那一部分字符串
|
fn:toLowerCase(string)
|
將參數(shù)string所有的字符變?yōu)樾?xiě),并將其返回
|
fn:toUpperCase(string)
|
將參數(shù)string所有的字符變?yōu)榇髮?xiě),并將其返回
|
fn:trim(string)
|
去除參數(shù)string 首尾的空格,并將其返回
|
摘要:
閱讀全文
摘要:
閱讀全文
摘要:
閱讀全文
posted @
2009-03-31 17:32 圣克爾·光 閱讀(21228) |
評(píng)論 (2) |
編輯 收藏
摘要:
閱讀全文