String.format() in java
Overview
In this article, we will cover format()
method of string class in java, why and how it is used with ample examples.
String.format()
String.format()
is a powerful tool in Java that allows you to format strings in a variety of ways.
You can use it to format numbers, dates, currencies, and other values. You can even use it to create complex strings with multiple lines and placeholders.
Syntax
String.format()
accepts two arguments.
1. A string that you want to format.
This string can be anything, but it must contain what are called format specifiers.
Format specifiers are placeholders for variables that you want to insert into the string.
Placeholders are denoted by a %
symbol followed by a pre-defined letters. An example of a placeholder is %s
, which is used for string values.
2. Values to be inserted into the placeholders in the format string.
String.format()
returns a string with placeholders replaced with corresponding values.
String.format() example
Below is a simple example to understand the usage of String.format()
.
String language = "java"; String unfmt = "Learning %s language"; String fmt = String.format(unfmt, language); System.out.print(fmt);
Here, the placeholder %s
in the first argument is replaced with the second argument value.
This prints
Understanding java language
Formatting multiple values
We can substitute values from multiple variables in a string at once as well.
Also, these values can be of different types as shown below
int number = 123; double amount = 123.45; String s = "abc"; String fmt = String.format("Number is %d, " + "String is %s, " + "Amount is %f", number, s, amount); System.out.println(fmt);
In this example, we replace three different values in a single string.
All these values are of different data types and the string produced by format()
is
Number is 123, String is abc, Amount is 123.450000
Notice that it appended 0’s after double value, which is not required.
Also, at times you might want to display values only till specific decimal values.
With format()
, you can define the precision of decimal values using point(.
) after %
, followed by the number of digits to be displayed such as %.2f
. Example,
double amt = 123.45; // remove trailing zeroes System.out.println(String.format("%.2f", amt)); double large = 123.46564; // display only 3 decimal places System.out.println(String.format("%.3f", large));
Output is
123.45
123.465
Below is a list of format options that can be used with String.format()
Option | Description |
---|---|
b, B | For formatting boolean values, true or false .If the value to be formatted is null, it returns false . |
h, H | For formatting to hexadecimal. |
s, S | For formatting values of type string. |
d | For formatting integer values. |
f | For formatting decimal or floating point values. |
x, X | For formatting to hexadecimal but the value to be formatted should be an integer. |
o | For formatting to octal. |
n | Adding platform specific line-separator |
t, T | For formatting date/time values. |
Lower and upper case letters return result in corresponding case.
This list can be found here.
If the value to be converted to hexadecimal is a string, then use
h
, H
flags.If the value to be converted to hexadecimal is an integer, then use
x
or X
flags. Examples,
System.out.println( String.format("123 in hex is %x", 123)); System.out.println( String.format("12g in hex is %h", "12g")); System.out.println( String.format("12g in hex is %H", "12g"));
Output is
123 in hex is 7b
12g in hex is be66
12g in hex is BE66
Formatting to octal
Use o flag with String.format()
to format a value to octal. Example,
System.out.println( String.format("123 in octal is %o", 123));
Output is
123 in octal is 173
Formatting dates
%t
along with D
flag is used to format date. The value should be of type java.util.Date
.
D
flag will format the date in mm/dd/yy format. To convert to other formats, use Y
, m
and d
flags for year, month and day, as shown below
Date d = new Date(); System.out.println(String.format("%tD", d)); System.out.println(String.format("%tY-%tm-%td", d,d,d));
Output is
12/18/22
2022-12-18
To print the last two digits of year, y
flag is used.
Formatting time
%t
along with T
flag is used to format time. The value should be of type java.util.Date
.
T
flag will format the time in hh:mm:ss format. To convert to other formats, use H
, M
and S
flags for hour, minute and second, as shown below
Date d = new Date(); System.out.println(String.format("%tT", d)); System.out.println(String.format("%tH:%tM", d,d,d));
Output is
12:17:16
12:17
Sometimes you might want to display a value between fixed widths while the value to be displayed is lesser than the width.
In such cases, you need to add empty spaces or 0s before the values. This is called padding.
String.format()
provides support to pad a value with both spaces and 0s simply by providing the width before the appropriate flag as shown below
int number = 123; System.out.println( String.format("Value padded with spaces %5d", number)); System.out.println( String.format("Value padded with zeroes %05d", number));
Output is
Value padded with spaces 123
Value padded with zeroes 00123
Local specific formatting
With String.format()
, you can format values specific to a locale by providing locale as the first argument.
There is an overloaded format()
method which takes 3 arguments as below
public static String format(Locale l, String format, Object… args)
Example is
double amount = 123.4534; String fmt = String.format("Amount in default locale " + " is %.2f ", amount); System.out.println(fmt); fmt = String.format(Locale.FRENCH, "Amount in french locale is %.2f ", amount); System.out.println(fmt);
Output is
Amount in default locale is 123.45
Amount in french locale is 123,45
Look, the second value is formatted in french locale, since we have ,
in place of .
Pass values from array
If there are multiple values to be formatted in a single string, then the argument list can become too long as in the below example
int n1 = 47, n2 = 64, n3 = 96; String text = "Result"; System.out.println( String.format("%s: Hex: %x, Octal: %o, " + " Decimal: %d", text, n1, n2, n3));
This, not only becomes complex but more error prone.
To solve this, format()
also accepts an array in place of multiple values as shown below
int n1 = 47, n2 = 64, n3 = 96; String text = "Result"; // define an array Object[] arr = {text, n1, n2, n3}; System.out.println( String.format("%s: Hex: %x, Octal: %o, Decimal: %d", arr));
Array values are replaced in the order of their indexes. That is, first placeholder will be replaced with first array element and so on.
So, you need to be careful with the order of array elements.
Another way is to define the index of array element along with placeholder using position and $
symbol with format symbol such as %2$s
, which references second element. Example,
int n1 = 47, n2 = 64, n3 = 96; String text = "Result"; Object[] arr = {text, n1, n2, n3}; System.out.println( String.format("%1$s: Hex: %2$x, Octal: %3$o, " + " Decimal: %4$d", arr));
String.format()
method in java. Hope the article was useful.