摘要:
閱讀全文
posted @
2009-06-07 02:29 圣克爾·光 閱讀(1022) |
評論 (0) |
編輯 收藏
摘要:
閱讀全文
posted @
2009-06-07 02:27 圣克爾·光 閱讀(9982) |
評論 (0) |
編輯 收藏
StringUtils 方法的操作對象是 java.lang.String 類型的對象,是 JDK 提供的 String 類型操作方法的補充,并且是 null 安全的(即如果輸入?yún)?shù) String 為 null 則不會拋出 NullPointerException ,而是做了相應(yīng)處理,例如,如果輸入為 null 則返回也是 null 等,具體可以查看源代碼)。
除了構(gòu)造器,StringUtils 中一共有130多個方法,并且都是 static 的,所以我們可以這樣調(diào)用 StringUtils.xxx()
下面分別對一些常用方法做簡要介紹:
1. public static boolean isEmpty(String str)
判斷某字符串是否為空,為空的標準是 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)
判斷某字符串是否為空或長度為0或由空白符(whitespace) 構(gòu)成
下面是示例:
StringUtils.isBlank(null) = true
StringUtils.isBlank("") = true
StringUtils.isBlank(" ") = true
StringUtils.isBlank(" ") = true
StringUtils.isBlank("\t \n \f \r") = true //對于制表符、換行符、換頁符和回車符
StringUtils.isBlank() //均識為空白符
StringUtils.isBlank("\b") = false //"\b"為單詞邊界符
StringUtils.isBlank("bob") = false
StringUtils.isBlank(" bob ") = false
4. public static boolean isNotBlank(String str)
判斷某字符串是否不為空且長度不為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)
對字符串?dāng)?shù)組中的每個字符串進行 strip(String str) ,然后返回。
如果 strs 為 null 或 strs 長度為0,則返回 strs 本身
15. public static String[] stripAll(String[] strs, String stripChars)
對字符串?dāng)?shù)組中的每個字符串進行 strip(String str, String stripChars) ,然后返回。
如果 strs 為 null 或 strs 長度為0,則返回 strs 本身
16. public static boolean equals(String str1, String str2)
比較兩個字符串是否相等,如果兩個均為空則也認為相等。
17. public static boolean equalsIgnoreCase(String str1, String str2)
比較兩個字符串是否相等,不區(qū)分大小寫,如果兩個均為空則也認為相等。
18. public static int indexOf(String str, char searchChar)
返回字符 searchChar 在字符串 str 中第一次出現(xiàn)的位置。
如果 searchChar 沒有在 str 中出現(xiàn)則返回-1,
如果 str 為 null 或 "" ,則也返回-1
19. public static int indexOf(String str, char searchChar, int startPos)
返回字符 searchChar 從 startPos 開始在字符串 str 中第一次出現(xiàn)的位置。
如果從 startPos 開始 searchChar 沒有在 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 開始在字符串 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) 方法的用法
如果我們需要把某個字符串拆分為字符串?dāng)?shù)組,則通常用 split(String regex) 來實現(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 是正則表達式 (regular expression) 而不是普通字符串,而 "." 在正則表達式中有特殊含義,表示匹配所有單個字符。如果要那樣拆分,我們必須給 "." 進行轉(zhuǎn)義,String[] strArray = str.split(".") 修改為 String[] strArray = str.split("\\.") 即可。
另外有關(guān) StringUtils 的詳細 API 請參見官方網(wǎng)站: http://commons.apache.org/lang/api/org/apache/commons/lang/StringUtils.html
posted @
2009-05-14 01:09 圣克爾·光 閱讀(329) |
評論 (0) |
編輯 收藏
所有標簽:
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點00分23秒)
<fmt:formatDate value="<%=new Date() %>" pattern="yyyy年MM月dd日HH點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>:資源綁定。除了以前提到過的在web.xml中聲明以外,還可以利用此標簽。
例<fmt:bundle basename="message"></fmt:bundle>
<fmt:setLocale>:設(shè)置locale,主要是用于這種情況,一個中國人在國外,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" 輸入日期也同時輸出具體時間
timeStyle="long" 時間以“長”格式輸出 差別:下午02時06分59秒 與 14:06:59
dateStyle="long" 日期以“長”格式輸出 差別:2006年9月7日 與 2006-9-7
四種長短參數(shù):long,short,medium,full
<fmt:timeZone value="${timezone}"/> 時區(qū)偏移,與上面可配合使用:
<fmt:formatDate value="$1661666" timeZone="${zn}" type="both" />
<fmt:parseDate var="i" type="date" value="2006-12-11" />
<c:out value="${i}" escapeXml="false" /> 分析出時間
posted @
2009-05-14 01:03 圣克爾·光 閱讀(1646) |
評論 (0) |
編輯 收藏
JSTL使用表達式來簡化頁面的代碼,這對一些標準的方法,例如bean的getter/setter方法,請求參數(shù)或者context以及session中的數(shù)據(jù)的訪問非常方便,但是我們在實際應(yīng)用中經(jīng)常需要在頁面調(diào)用對象的某些方法,例如我需要調(diào)用字符串的length方法來獲取字符串的長度時,在以往的開發(fā)過程中我們必須把對象先轉(zhuǎn)為String類,然后在調(diào)用其length方法,這樣的代碼繁瑣而且容易出錯。
因此JSTL內(nèi)置了幾個用于字符串操作的方法,可以直接在表達式中使用,大大的簡化了代碼,提供代碼的可讀性。在JSTL的表達是中要使用一個函數(shù),其格式如下
${ns:methodName(args....)}
在使用這些函數(shù)之前必須在JSP中引入標準函數(shù)的聲明
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
下面是JSTL中自帶的方法列表以及其描述
函數(shù)名 |
函數(shù)說明 |
使用舉例 |
fn:contains |
判斷字符串是否包含另外一個字符串 |
<c:if test="${fn:contains(name, searchString)}"> |
fn:containsIgnoreCase |
判斷字符串是否包含另外一個字符串(大小寫無關(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)合成一個新字符串,并使用指定字符格開 |
${fn:join(array, ";")} |
fn:length |
獲取字符串的長度,或者數(shù)組的大小 |
${fn:length(shoppingCart.products)} |
fn:replace |
替換字符串中指定的字符 |
${fn:replace(text, "-", "")} |
fn:split |
把字符串按照指定字符切分 |
${fn:split(customerNames, ";")} |
fn:startsWith |
判斷字符串是否以某個子串開始 |
<c:if test="${fn:startsWith(product.id, "100-")}"> |
fn:substring |
獲取子串 |
${fn:substring(zip, 6, -1)} |
fn:substringAfter |
獲取從某個字符所在位置開始的子串
|
${fn:substringAfter(zip, "-")} |
fn:substringBefore |
獲取從開始到某個字符所在位置的子串 |
${fn:substringBefore(zip, "-")} |
fn:toLowerCase |
轉(zhuǎn)為小寫 |
${fn.toLowerCase(product.name)} |
fn:toUpperCase |
轉(zhuǎn)為大寫字符 |
${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(忽略大小寫),返回true
|
fn:endsWith(string, suffix)
|
如果參數(shù) string 以參數(shù)suffix結(jié)尾,返回true
|
fn:escapeXml(string)
|
將有特殊意義的XML (和HTML)轉(zhuǎn)換為對應(yīng)的XML character entity code,并返回
|
fn:indexOf(string, substring)
|
返回參數(shù)substring在參數(shù)string中第一次出現(xiàn)的位置
|
fn:join(array, separator)
|
將一個給定的數(shù)組array用給定的間隔符separator串在一起,組成一個新的字符串并返回。
|
fn:length(item)
|
返回參數(shù)item中包含元素的數(shù)量。參數(shù)Item類型是數(shù)組、collection或者String。如果是String類型,返回值是String中的字符數(shù)。
|
fn:replace(string, before, after)
|
返回一個String對象。用參數(shù)after字符串替換參數(shù)string中所有出現(xiàn)參數(shù)before字符串的地方,并返回替換后的結(jié)果
|
fn:split(string, separator)
|
返回一個數(shù)組,以參數(shù)separator 為分割符分割參數(shù)string,分割后的每一部分就是數(shù)組的一個元素
|
fn:startsWith(string, prefix)
|
如果參數(shù)string以參數(shù)prefix開頭,返回true
|
fn:substring(string, begin, end)
|
返回參數(shù)string部分字符串, 從參數(shù)begin開始到參數(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)樾?,并將其返?/p>
|
fn:toUpperCase(string)
|
將參數(shù)string所有的字符變?yōu)榇髮?,并將其返?/p>
|
fn:trim(string)
|
去除參數(shù)string 首尾的空格,并將其返回
|
posted @
2009-05-14 00:58 圣克爾·光 閱讀(300) |
評論 (0) |
編輯 收藏
摘要:
閱讀全文
posted @
2009-04-01 15:32 圣克爾·光 閱讀(304) |
評論 (0) |
編輯 收藏
摘要:
閱讀全文
posted @
2009-04-01 15:29 圣克爾·光 閱讀(467) |
評論 (0) |
編輯 收藏
摘要:
閱讀全文
posted @
2009-03-31 17:32 圣克爾·光 閱讀(21228) |
評論 (2) |
編輯 收藏