java填充字符串_Java字符串右补齐——String.format
Java字符串右补齐⽅法:
System.out.println(String.format("%-4s", "ab")); //“%-4s”可将不⾜4位的补齐,右补齐空字符,输出:“ab ”
更详细的参考java.util.Formatter如下:
public final class Formatterextends Objectimplements Closeable, Flushable
printf 风格的格式字符串的解释程序。此类提供了对布局对齐和排列的⽀持,以及对数值、字符串和⽇期/时间数据的常规格式和特定于语⾔环境的输出的⽀持。⽀持诸如 byte、BigDecimal 和 Calendar 等常见 Java 类型。任意⽤户类型的受限格式化定制都是通
过 Formattable 接⼝提供的。
Formatter 对于多线程访问⽽⾔没必要是安全的。线程安全是可选的,它对此类中的⽅法⽤户负责。
Java 语⾔的格式化输出在很⼤程度上受到 C 语⾔ printf 的启发。虽然⼀些格式字符串与 C 类似,但已
进⾏了某些定制,以适应 Java 语⾔,并且利⽤了其中⼀些特性。此外,Java 的格式⽐ C 的格式更严格;例如,如果转换与标志不兼容,则会抛出异常。在 C 中,不适⽤的标志会被忽略。这样,便于 C 程序员识别这些格式字符串,⽽⼜不必与 C 中的那些标志完全兼容。
所期望⽤法的⽰例:
StringBuilder sb = new StringBuilder();
// Send all output to the Appendable object sb
Formatter formatter = new Formatter(sb, Locale.US);
// Explicit argument indices may be used to re-order output.
formatter.format("%4$2s %3$2s %2$2s %1$2s", "a", "b", "c", "d")
// -> " d c b a"
// Optional locale as the first argument can be used to get
// locale-specific formatting of numbers. The precision and width can be
// given to round and align the value.
formatter.format(Locale.FRANCE, "e = %+10.4f", Math.E);
// -> "e = +2,7183"
// The '(' numeric flag may be used to format negative numbers with
// parentheses rather than a minus sign. Group separators are
// automatically inserted.
formatter.format("Amount gained or lost since last statement: $ %(,.2f",
balanceDelta);
// -> "Amount gained or lost since last statement: $ (6,217.58)"
常见格式化请求的便捷⽅法是按照如下调⽤格式来阐明的:c++string类型
// Writes a formatted string to System.out.
System.out.format("Local time: %tT", Instance());
// -> "Local time: 13:34:18"
// Writes formatted output
fileName, Message());
// -> "Unable to open file 'food': No such file or directory"
与 C 语⾔的 sprintf(3) 类似,可以使⽤静态⽅法 String#format()String.format 来格式化 Strings:
// Format a string containing a date.
import java.util.Calendar;
import java.util.GregorianCalendar;
import static java.util.Calendar.*;
Calendar c = new GregorianCalendar(1995, MAY, 23);
String s = String.format("Duke's Birthday: %1$tm %1$te,%1$tY", c);
// -> s == "Duke's Birthday: May 23, 1995"
结构
此规范分为两部分。第⼀部分是摘要,包括基本的格式概念。这⼀部分是为那些想要快速⼊门并熟悉其他编程语⾔的格式化输出的⽤户准备的。第⼆部分是详细信息,包括具体的实现细节。它是为那些需要更精确格式化⾏为规范的⽤户准备的。
摘要
这⼀部分将提供对格式概念的简单概述。有关精确的⾏为细节,请参阅详细信息部分。
格式字符串语法
产⽣格式化输出的每个⽅法都需要格式字符串 和参数列表。格式字符串是⼀个 String,它可以包含固定⽂本以及⼀个或多个嵌⼊的格式说明符。请考虑以下⽰例:
Calendar c = ...;
String s = String.format("Duke's Birthday: %1$tm %1$te,%1$tY", c);
此格式字符串是 format ⽅法的第⼀个参数。它包含三个格式说明符 "%1$tm"、"%1$te" 和 "%1$tY",它们指出应该如何处理参数以及在⽂本的什么地⽅插⼊它们。格式字符串的其余部分是包括 "Dukes Birthday: " 和其他任何空格或标点符号的固定⽂本。 参数列表由传递给位于格式字符串之后的⽅法的所有参数组成。在上述⽰例中,参数列表的⼤⼩为 1,由对象 Calendar c 组成。
常规类型、字符类型和数值类型的格式说明符的语法如下:
%[argument_index$][flags][width][.precision]conversion
可选的 argument_index 是⼀个⼗进制整数,⽤于表明参数在参数列表中的位置。第⼀个参数由 "1$" 引⽤,第⼆个参数由 "2$" 引⽤,依此类推。
可选 flags 是修改输出格式的字符集。有效标志集取决于转换类型。
可选 width 是⼀个⾮负⼗进制整数,表明要向输出中写⼊的最少字符数。
可选 precision 是⼀个⾮负⼗进制整数,通常⽤来限制字符数。特定⾏为取决于转换类型。
所需 conversion 是⼀个表明应该如何格式化参数的字符。给定参数的有效转换集取决于参数的数据类型。
⽤来表⽰⽇期和时间类型的格式说明符的语法如下:
%[argument_index$][flags][width]conversion
可选的 argument_index、flags 和 width 的定义同上。
所需的 conversion 是⼀个由两字符组成的序列。第⼀个字符是 't' 或 'T'。第⼆个字符表明所使⽤的格式。这些字符类似于但不完全等同于那些由 GNU date 和 POSIX strftime(3c) 定义的字符。
与参数不对应的格式说明符的语法如下:
%[flags][width]conversion
可选 flags 和 width 的定义同上。
所需的 conversion 是⼀个表明要在输出中所插内容的字符。
转换
转换可分为以下⼏类:
常规 - 可应⽤于任何参数类型
字符 - 可应⽤于表⽰ Unicode 字符的基本类型:char、Character、byte、Byte、short 和 Short。
当 Character.isValidCodePoint(int) 返回 true时,可将此转换应⽤于 int 和 Integer 类型
数值整数 - 可应⽤于 Java 的整数类型:byte、Byte、short、Short、int、Integer、long、Long 和 BigInteger
浮点 - 可⽤于 Java 的浮点类型:float、Float、double、Double 和 BigDecimal
⽇期/时间 - 可应⽤于 Java 的、能够对⽇期或时间进⾏编码的类型:long、Long、Calendar 和 Date。
百分⽐ - 产⽣字⾯值 '%' ('\u0025')
⾏分隔符 - 产⽣特定于平台的⾏分隔符
下表总结了受⽀持的转换。由⼤写字符(如 'B'、'H'、'S'、'C'、'X'、'E'、'G'、'A' 和 'T')表⽰的转换与由
相应的⼩写字符的转换等同,根据流⾏的Locale 规则将结果转换为⼤写形式除外。后者等同于 UpperCase() 的以下调⽤
转换参数类别说明
'b','B'
常规
如果参数 arg 为 null,则结果为 "false"。如果 arg 是⼀个 boolean 值或 Boolean,则结果为 String.valueOf() 返回的字符串。否则结果为 "true"。
'h','H'
常规
如果参数 arg 为 null,则结果为 "null"。否则,结果为调⽤ HexString(arg.hashCode()) 得到的结果。
's','S'
常规
如果参数 arg 为 null,则结果为 "null"。如果 arg 实现 Formattable,则调⽤ arg.formatTo。否则,结果为调⽤ String()得到的结果。
'c','C'
字符
结果是⼀个 Unicode 字符
'd'
整数
结果被格式化为⼗进制整数
'o'
整数
结果被格式化为⼋进制整数
'x','X'
整数
结果被格式化为⼗六进制整数
'e','E'
浮点
结果被格式化为⽤计算机科学记数法表⽰的⼗进制数
'f'
浮点
结果被格式化为⼗进制数
'g','G'
浮点
根据精度和舍⼊运算后的值,使⽤计算机科学记数形式或⼗进制格式对结果进⾏格式化。
'a','A'
浮点
结果被格式化为带有效位数和指数的⼗六进制浮点数
't','T'
⽇期/时间
⽇期和时间转换字符的前缀。请参阅⽇期/时间转换。
'%'
百分⽐
结果为字⾯值 '%' ('\u0025')
'n'
⾏分隔符
结果为特定于平台的⾏分隔符
任何未明确定义为转换的字符都是⾮法字符,并且都被保留,以供将来扩展使⽤。
⽇期/时间转换
以下⽇期和时间转换的后缀字符是为 't' 和 'T' 转换定义的。这些类型相似于但不完全等同于那些由 GNU date 和 POSIX strftime(3c) 定义的类型。提供其他转换类型是为了访问特定于 Java 的功能(如将 'L' ⽤作秒中的毫秒)。
以下转换字符⽤来格式化时间:
'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 之间的差值。
以下转换字符⽤来格式化⽇期:
'B'
特定于语⾔环境的⽉份全称,例如 "January" 和 "February"。
'b'
特定于语⾔环境的⽉份简称,例如 "Jan" 和 "Feb"。
'h'
与 'b' 相同。
'A'

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。