Java中String.format的用法总结
1.对整数进行格式化:%[index$][标识][最小宽度]转换方式
我们可以看到,格式化字符串由4部分组成,其中%[index$]的含义我们上面已经讲过,[最小宽度]的含义也很好理解,就是最终该整数转化的字符串最少包含多少位数字。我们来看看剩下2个部分的含义吧:
标识:
1
2
3
4
5
6
7
|
'-' 在最小宽度内左对齐,不可以与“用 0 填充”同时使用 '#' 只适用于 8 进制和 16 进制, 8 进制时在结果前面增加一个 0 , 16 进制时在结果前面增加0x '+' 结果总是包括一个符号(一般情况下只适用于 10 进制,若对象为BigInteger才可以用于 8 进制和 16 进制) ' ' 正值前加空格,负值前加负号(一般情况下只适用于 10 进制,若对象为BigInteger才可以用于 8 进制和 16 进制) '0' 结果将用零来填充 ',' 只适用于 10 进制,每 3 位数字之间用“,”分隔 '(' 若参数是负数,则结果中不添加负号而是用圆括号把数字括起来(同‘+'具有同样的限制) |
转换方式:
1
|
d-十进制 o-八进制 x或X-十六进制 |
上面的说明过于枯燥,我们来看几个具体的例子。需要特别注意的一点是:大部分标识字符可以同时使用。
1
2
3
4
5
6
7
8
9
10
11
12
|
System.out.println(String.format( "%1$,09d" , - 3123 )); System.out.println(String.format( "%1$9d" , - 31 )); System.out.println(String.format( "%1$-9d" , - 31 )); System.out.println(String.format( "%1$(9d" , - 31 )); System.out.println(String.format( "%1$#9x" , 5689 )); //结果为: //-0003,123 // -31 //-31 // (31) // 0x1639 |
2.对浮点数进行格式化:%[index$][标识][最少宽度][.精度]转换方式
我们可以看到,浮点数的转换多了一个“精度”选项,可以控制小数点后面的位数。
标识:
1
2
3
4
5
6
|
'-' 在最小宽度内左对齐,不可以与“用 0 填充”同时使用 '+' 结果总是包括一个符号 ' ' 正值前加空格,负值前加负号 '0' 结果将用零来填充 ',' 每 3 位数字之间用“,”分隔(只适用于fgG的转换) '(' 若参数是负数,则结果中不添加负号而是用圆括号把数字括起来(只适用于eEfgG的转换) |
转换方式:
1
2
3
4
|
'e' , 'E' -- 结果被格式化为用计算机科学记数法表示的十进制数 'f' -- 结果被格式化为十进制普通表示方式 'g' , 'G' -- 根据具体情况,自动选择用普通表示方式还是科学计数法方式 'a' , 'A' -- 结果被格式化为带有效位数和指数的十六进制浮点数 |
3.对字符进行格式化:
对字符进行格式化是非常简单的,c表示字符,标识中'-'表示左对齐,其他就没什么了。
4.对百分比符号进行格式化:
看了上面的说明,大家会发现百分比符号“%”是特殊格式的一个前缀。那么我们要输入一个百分比符号该怎么办呢?肯定是需要转义字符的,但是要注意的是,在这里转义字符不是“\”,而是“%”。换句话说,下面这条语句可以输出一个“12%”:
System.out.println(String.format("%1$d%%", 12));
5.取得平台独立的行分隔符:
System.getProperty("line.separator")可以取得平台独立的行分隔符,但是用在format中间未免显得过于烦琐了。于是format函数自带了一个平台独立的行分隔符那就是String.format("%n")。
6.对日期类型进行格式化:
以下日期和时间转换的后缀字符是为 't' 和 'T' 转换定义的。这些类型相似于但不完全等同于那些由 GNU date 和 POSIX strftime(3c) 定义的类型。提供其他转换类型是为了访问特定于 Java 的功能(如将 'L' 用作秒中的毫秒)。
以下转换字符用来格式化时间:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
'H' 24 小时制的小时,被格式化为必要时带前导零的两位数,即 00 - 23 。 'I' 12 小时制的小时,被格式化为必要时带前导零的两位数,即 01 - 12 。 'k' 24 小时制的小时,即 0 - 23 。 'l' 12 小时制的小时,即 1 - 12 。 'M' 小时中的分钟,被格式化为必要时带前导零的两位数,即 00 - 59 。 'S' 分钟中的秒,被格式化为必要时带前导零的两位数,即 00 - 60 ( "60" 是支持闰秒所需的一个特殊值)。 'L' 秒中的毫秒,被格式化为必要时带前导零的三位数,即 000 - 999 。 'N' 秒中的毫微秒,被格式化为必要时带前导零的九位数,即 000000000 - 999999999 。 'p' 特定于语言环境的 上午或下午 标记以小写形式表示,例如 "am" 或 "pm" 。使用转换前缀 'T' 可以强行将此输出转换为大写形式。 'z' 相对于 GMT 的 RFC 822 格式的数字时区偏移量,例如 - 0800 。 'Z' 表示时区缩写形式的字符串。Formatter 的语言环境将取代参数的语言环境(如果有)。 's' 自协调世界时 (UTC) 1970 年 1 月 1 日 00 : 00 : 00 至现在所经过的秒数,即 Long.MIN_VALUE/ 1000 与 Long.MAX_VALUE/ 1000 之间的差值。 'Q' 自协调世界时 (UTC) 1970 年 1 月 1 日 00 : 00 : 00 至现在所经过的毫秒数,即 Long.MIN_VALUE 与 Long.MAX_VALUE 之间的差值。 |
以下转换字符用来格式化日期:
1
2
3
4
5
6
7
8
9
10
11
12
|
'B' 特定于语言环境的月份全称,例如 "January" 和 "February" 。 'b' 特定于语言环境的月份简称,例如 "Jan" 和 "Feb" 。 'h' 与 'b' 相同。 'A' 特定于语言环境的星期几全称,例如 "Sunday" 和 "Monday" 'a' 特定于语言环境的星期几简称,例如 "Sun" 和 "Mon" 'C' 除以 100 的四位数表示的年份,被格式化为必要时带前导零的两位数,即 00 - 99 'Y' 年份,被格式化为必要时带前导零的四位数(至少),例如, 0092 等于格里高利历的 92 CE。 'y' 年份的最后两位数,被格式化为必要时带前导零的两位数,即 00 - 99 。 'j' 一年中的天数,被格式化为必要时带前导零的三位数,例如,对于格里高利历是 001 - 366 。 'm' 月份,被格式化为必要时带前导零的两位数,即 01 - 13 。 'd' 一个月中的天数,被格式化为必要时带前导零两位数,即 01 - 31 'e' 一个月中的天数,被格式化为两位数,即 1 - 31 。 |
以下转换字符用于格式化常见的日期/时间组合。
1
2
3
4
5
6
|
'R' 24 小时制的时间,被格式化为 "%tH:%tM" 'T' 24 小时制的时间,被格式化为 "%tH:%tM:%tS" 。 'r' 12 小时制的时间,被格式化为 "%tI:%tM:%tS %Tp" 。上午或下午标记 ( '%Tp' ) 的位置可能与语言环境有关。 'D' 日期,被格式化为 "%tm/%td/%ty" 。 'F' ISO 8601 格式的完整日期,被格式化为 "%tY-%tm-%td" 。 'c' 日期和时间,被格式化为 "%ta %tb %td %tT %tZ %tY" ,例如 "Sun Jul 20 16:17:00 EDT 1969" 。 |
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!