format_currency
The format_currency
filter formats a number as a currency:
1 2
{# €1,000,000.00 #}
{{ '1000000'|format_currency('EUR') }}
You can pass attributes to tweak the output:
1 2 3 4 5
{# €12.34 #}
{{ '12.345'|format_currency('EUR', {rounding_mode: 'floor'}) }}
{# €1,000,000.0000 #}
{{ '1000000'|format_currency('EUR', {fraction_digit: 4}) }}
The list of supported options:
grouping_used
: Specifies whether to use grouping separator for thousands:1 2
{# €1,234,567.89 #} {{ 1234567.89 | format_currency('EUR', {grouping_used:true}, 'en') }}
decimal_always_shown
: Specifies whether to always show the decimal part, even if it's zero:1 2
{# €123.00 #} {{ 123 | format_currency('EUR', {decimal_always_shown:true}, 'en') }}
max_integer_digit
:min_integer_digit
:integer_digit
: Define constraints on the integer part:1 2
{# €345.68 #} {{ 12345.6789 | format_currency('EUR', {max_integer_digit:3, min_integer_digit:2}, 'en') }}
max_fraction_digit
:min_fraction_digit
:fraction_digit
: Define constraints on the fraction part:1 2
{# €123.46 #} {{ 123.456789 | format_currency('EUR', {max_fraction_digit:2, min_fraction_digit:1}, 'en') }}
multiplier
: Multiplies the value before formatting:1 2
{# €123,000.00 #} {{ 123 | format_currency('EUR', {multiplier:1000}, 'en') }}
grouping_size
:secondary_grouping_size
: Set the size of the primary and secondary grouping separators:1 2
{# €1,23,45,678.00 #} {{ 12345678 | format_currency('EUR', {grouping_size:3, secondary_grouping_size:2}, 'en') }}
rounding_mode
:rounding_increment
: Control rounding behavior, here is a list of all rounding_mode available:ceil
: Ceiling roundingfloor
: Floor roundingdown
: Rounding towards zeroup
: Rounding away from zerohalf_even
: Round halves to the nearest even integerhalf_up
: Round halves uphalf_down
: Round halves down
1 2
{# €123.50 #} {{ 123.456 | format_currency('EUR', {rounding_mode:'ceiling', rounding_increment:0.05}, 'en') }}
format_width
:padding_position
: Set width and padding for the formatted number, here is a list of all padding_position available:before_prefix
: Pad before the currency symbolafter_prefix
: Pad after the currency symbolbefore_suffix
: Pad before the suffix (currency symbol)after_suffix
: Pad after the suffix (currency symbol)
1 2
{# €123.00 #} {{ 123 | format_currency('EUR', {format_width:10, padding_position:'before_suffix'}, 'en') }}
significant_digits_used
:min_significant_digits_used
:max_significant_digits_used
: Control significant digits in formatting:1 2
{# €123.4568 #} {{ 123.456789 | format_currency('EUR', {significant_digits_used:true, min_significant_digits_used:4, max_significant_digits_used:7}, 'en') }}
lenient_parse
: If true, allows lenient parsing of the input:1 2
{# €123.00 #} {{ 123 | format_currency('EUR', {lenient_parse:true}, 'en') }}
By default, the filter uses the current locale. You can pass it explicitly:
1 2
{# 1.000.000,00 € #}
{{ '1000000'|format_currency('EUR', locale: 'de') }}
Note
The format_currency
filter is part of the IntlExtension
which is not
installed by default. Install it first:
1
$ composer require twig/intl-extra
Then, on Symfony projects, install the twig/extra-bundle
:
1
$ composer require twig/extra-bundle
Otherwise, add the extension explicitly on the Twig environment:
1 2 3 4
use Twig\Extra\Intl\IntlExtension;
$twig = new \Twig\Environment(...);
$twig->addExtension(new IntlExtension());
Arguments
currency
: The currency (ISO 4217 code)attrs
: A map of attributeslocale
: The locale code as defined in RFC 5646
Note
Internally, Twig uses the PHP NumberFormatter::formatCurrency function.