Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Jinja Templates - Format a float as comma-separated currency

I'm trying to format a float as comma-separated currency. E.g. 543921.9354 becomes $543,921.94. I'm using the format filter in Jinja templates, which seems to mimic the % operator in Python rather than the Python format function?

How can I accomplish this formatting in Jinja? Is it possible using the format filter? This is what I have so far, which accomplishes everything except the commas:

"$%.2f"|format(543921.9354)

which of course yields

$543921.94

like image 561
Kyle Johnson Avatar asked Aug 22 '12 17:08

Kyle Johnson


2 Answers

Update: Using Jinja2 and Python 3, this worked quite nicely in the template without having to define any custom code:

{{ "${:,.2f}".format(543921.9354) }} 

I'm not sure exactly what the dependencies are to have this work, but IMHO anyone else reading this answer would do well to at least try it before worrying about custom filters.

like image 139
biomiker Avatar answered Sep 23 '22 13:09

biomiker


Write a custom filter for that. If you are using python 2.7, it can look like this:

def format_currency(value):     return "${:,.2f}".format(value) 
like image 39
alex vasi Avatar answered Sep 22 '22 13:09

alex vasi