std::format_to

Header: <format>

Format args according to the format string fmt, and write the result to the output iterator out. If present, loc is used for locale-specific formatting.

# Declarations

template< class OutputIt, class... Args >
OutputIt format_to( OutputIt out,
std::format_string<Args...> fmt, Args&&... args );

(since C++20)

template< class OutputIt, class... Args >
OutputIt format_to( OutputIt out,
std::wformat_string<Args...> fmt, Args&&... args );

(since C++20)

template< class OutputIt, class... Args >
OutputIt format_to( OutputIt out, const std::locale& loc,
std::format_string<Args...> fmt, Args&&... args );

(since C++20)

template< class OutputIt, class... Args >
OutputIt format_to( OutputIt out, const std::locale& loc,
std::wformat_string<Args...> fmt, Args&&... args );

(since C++20)

# Parameters

# Return value

Iterator past the end of the output range.

# Notes

As of P2216R3, it is an error if the format string is not a constant expression. std::vformat_to or std::runtime_format(since C++26) can be used in this case.

# Example

#include <format>
#include <iostream>
#include <iterator>
#include <string>
 
int main()
{
    std::string buffer;
 
    std::format_to
    (
        std::back_inserter(buffer), // < OutputIt
        "Hello, C++{}!\n",          // < fmt
        "20"                        // < arg
    );
    std::cout << buffer;
    buffer.clear();
 
    std::format_to
    (
        std::back_inserter(buffer), // < OutputIt
        "Hello, {0}::{1}!{2}",      // < fmt
        "std",                      // < arg {0}
        "format_to()",              // < arg {1}
        "\n",                       // < arg {2}
        "extra param(s)..."         // < unused
    );
    std::cout << buffer << std::flush;
 
    std::wstring wbuffer;
    std::format_to
    (
        std::back_inserter(wbuffer),// < OutputIt
        L"Hello, {2}::{1}!{0}",     // < fmt
        L"\n",                      // < arg {0}
        L"format_to()",             // < arg {1}
        L"std",                     // < arg {2}
        L"...is not..."             // < unused
        L"...an error!"             // < unused
    );
    std::wcout << wbuffer;
}

# Defect reports

DRApplied toBehavior as publishedCorrect behavior
LWG 3539C++20out could not be a move-only iteratorit can be
P2216R3C++20throws std::format_error for invalid format stringresults in compile-time error instead
P2418R2C++20objects that are neither const-usable nor copyable(such as generator-like objects) are not formattableallow formatting these objects
P2508R1C++20there’s no user-visible name for this facilitythe name basic_format_string is exposed

# See also