Format Strings
Explore what C++20 holds for formatting strings.
We'll cover the following
The formatting string syntax is identical for the formatting functions std::format
, std::format_to
, and std::format_to_n
. I use std::format
in my examples.
- Syntax:
std::format(FormatString, Args)
The format string FormatString
consists of
- Ordinary characters (except
{
and}
) - Escape sequences
{{
and}}
that are replaced by{
and}
- Replacement fields
A replacement field has the format { }
- You can use inside the replacement field an argument id and a colon followed by a format specification, both components are optional.
The argument id allows you to specify the index of the arguments in Args
. The ids start with 0. When you don’t provide the argument id, the fields are filled in the same order as the arguments are given. Either all replacement fields have to use an argument id or none; i.e., std::format("{}, {}", "Hello", "World")
and std::format("{1}, {0}", "World", "Hello")
will both compile, but std::format("{1}, {}", "World", "Hello")
won’t.
std::formatter
and its specializations define the format specification for the argument types.
- Basic types and
std::string
: standard format specification based on Python’s format specification - Chrono types: Chrono format specification
- Other formattable types: User-defined
std::formatter
specialization
I will use the next sections to fill in the theory with practice. Let me start with the argument id and continue with the format specification.
Argument ID
Thanks to the argument id, you can reorder the arguments or address particular arguments.
Get hands-on with 1300+ tech skills courses.