您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)Java如何實現(xiàn)格式化字符串,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
import java.beans.PropertyDescriptor; import java.lang.reflect.Method; import java.util.HashMap; import java.util.Map; import java.util.regex.Matcher; import java.util.regex.Pattern; public class StringFormatUtil { private static final Pattern pattern = Pattern.compile("\\{(.*?)\\}"); private static Matcher matcher; /** * 格式化字符串 字符串中使用{key}表示占位符 * * @param sourStr * 需要匹配的字符串 * @param param * 參數(shù)集 * @return */ public static String stringFormat(String sourStr, Map<String, Object> param) { String tagerStr = sourStr; if (param == null) return tagerStr; try { matcher = pattern.matcher(tagerStr); while (matcher.find()) { String key = matcher.group(); String keyclone = key.substring(1, key.length() - 1).trim(); Object value = param.get(keyclone); if (value != null) tagerStr = tagerStr.replace(key, value.toString()); } }catch (Exception e){ return null; } return tagerStr; } /** * 格式化字符串 字符串中使用{key}表示占位符 利用反射 自動獲取對象屬性值 (必須有g(shù)et方法) * * @param sourStr 需要匹配的字符串 * * @return */ public static String stringFormat(String sourStr, Object obj) { String tagerStr = sourStr; matcher = pattern.matcher(tagerStr); if (obj == null) return tagerStr; PropertyDescriptor pd; Method getMethod; // 匹配{}中間的內(nèi)容 包括括號 while (matcher.find()) { String key = matcher.group(); String keyclone = key.substring(1, key.length() - 1).trim(); try { pd = new PropertyDescriptor(keyclone, obj.getClass()); getMethod = pd.getReadMethod();// 獲得get方法 Object value = getMethod.invoke(obj); if (value != null) tagerStr = tagerStr.replace(key, value.toString()); } catch (Exception e) { // TODO Auto-generated catch block // Loggers.addException(e); } } return tagerStr; } /** * 格式化字符串 (替換所有) 字符串中使用{key}表示占位符 * * @param sourStr * 需要匹配的字符串 * @param param * 參數(shù)集 * @return */ public static String stringFormatAll(String sourStr, Map<String, Object> param) { String tagerStr = sourStr; if (param == null) return tagerStr; try { matcher = pattern.matcher(tagerStr); while (matcher.find()) { String key = matcher.group(); String keyclone = key.substring(1, key.length() - 1).trim(); Object value = param.get(keyclone); if (value != null) tagerStr = tagerStr.replace(key, value.toString()); } }catch (Exception e){ return null; } return tagerStr; } /** * 格式花字符串,按照占位符名字 * 輸入:sourStr = xxxxx{a}xxxx ,param = {a:A,b:B} * 輸出:targetStr = xxxxAxxxxB * @param sourStr * @param param * @return */ public static String stringFormat(String sourStr, JSONObject param) { String tagerStr = sourStr; if (param == null) return tagerStr; try { matcher = pattern.matcher(tagerStr); while (matcher.find()) { String key = matcher.group(); String keyclone = key.substring(1, key.length() - 1).trim(); Object value = param.get(keyclone); if (value != null) tagerStr = tagerStr.replace(key, value.toString()); } }catch (Exception e){ return null; } return tagerStr; } public static void main(String[] args) { // Map<String,Object> map = new HashMap<>(); // map.put("id","111"); // map.put("sss","ss"); // JSONObject json = new JSONObject(); // json.put("id","212"); // json.put("fff","xxxx"); // json.put("emmmmm",11); // stringFormat("sisas&{fff}_diwahwi%{id}{jio}",json); } }
補充知識:java中占位符的使用
二話不說,先上代碼
package com.string.format; public class StringFormat { //占位符%s,拼接sql,刪除兩個表中的數(shù)據(jù),條件是字符串?dāng)?shù)組類型的id public static void formSql(String tableName,String tableName2,String...strings){ //sql占位符 %s占位符 String sql="delete from %s,%s where id in (%s)"; //聲明新的字符串 String sqls=""; //遍歷字符串的參數(shù)數(shù)組 for (String str : strings) { //將參數(shù)數(shù)組拼接成字符串,用逗號分割 sqls += str + ","; } //拼接最后會多出個逗號,截取 sqls=sqls.substring(0, sqls.length()-1); //format第一個sql參數(shù)為目標(biāo)字符串,tableName,tableName2,為替換的兩表的名字,sqls為刪除數(shù)據(jù)的參數(shù)集合 String s=String.format(sql, tableName,tableName2,sqls); //輸出拼接后的sql System.out.println(s); } public static void main(String[] args) { //傳入?yún)?shù)為指定表名,和參數(shù)值 StringFormat.formSql("user","role", "1","3","5","7","9","33"); } }
其實,傳入的參數(shù)是數(shù)組類型的 值,我們也可以按array[0],array[1]的方式插入?yún)?shù),只是參數(shù)個數(shù)應(yīng)用不靈活,還是使用數(shù)組的方式取值比較好,
public static void format(){ String st="%s的%s的價格是%f,是否售罄%c,占總銷售的%d%%,庫存%d,是否為暢銷品%b"; String s=String.format(st, "58優(yōu)品","啤酒",3.5,'是',50,199,true); System.out.println(s); } public static void main(String[] args) { //傳入?yún)?shù)為指定表名,和參數(shù)值 //StringFormat.formSql("user","role", "1","3","5","7","9","33"); format(); }
public static void format(){ //String st="%s的%s的價格是%f,是否售罄%c,占總銷售的%d%%,庫存%d,是否為暢銷品%b"; //String s=String.format(st, "58優(yōu)品","啤酒",3.5,'是',50,199,true); //System.out.println(s); SimpleDateFormat simple=new SimpleDateFormat("yyyy年MM月dd日 HH點mm分ss秒"); String newDate=simple.format(new Date()); String st1="%s的%s的價格是%s,是否售罄%s,占總銷售的%s%%,庫存%s,是否為暢銷品%s,當(dāng)前日期為%s"; String ss=String.format(st1, "58優(yōu)品","啤酒","3.5",'是',"80","998","true",newDate); System.out.println(ss); } public static void main(String[] args) { //傳入?yún)?shù)為指定表名,和參數(shù)值 //StringFormat.formSql("user","role", "1","3","5","7","9","33"); format(); }
/*%S字符串類型的占位符 * %c字符類型的占位符 * %b布爾類型的占位符 * %d整數(shù)類型的占位符 * %%百分比類型的占位符 * %n換行類型的占位符 * %t時間類型的占位符 * c全部的日期時間類型 * F年-月-日格式 * D年/月/日格式 * rHH:MM:SS格式12小時制 * */
關(guān)于Java如何實現(xiàn)格式化字符串就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。