The input looks like 8.7000000
and I want to format it to look like 8.70 EUR
.
I considered using the DecimalFormat
class:
Double number = Double.valueOf(text);
DecimalFormat dec = new DecimalFormat("#.## EUR");
String credits = dec.format(number);
TextView tt = (TextView) findViewById(R.id.creditsView);
tt.setText(credits);
The result is 8.7 EUR
. How can I tell the formatter to have two digits after the .
?
I think a good option would be this aproach:
Using #,###.00
the result for the value 0.50 would be displayed like this:
$.50
However, if you use #,##0.00
the result for the same value would be:
$0.50
I found a nice solution in this link below
http://docs.oracle.com/javase/tutorial/i18n/format/decimalFormat.html
in short to represent a currency like 92323345465.30 as 92,323,345,465.30 just use ###,###,###,###.00
That is, whenever you use '0', then the '0' will either be replaced by another digit, or if there is no digit to replace it, then IT WILL APPEAR! But is you use '#' then if there is no number to replace the '#', then that space will be empty.
Remember that you can even add up your own symbols like $, etc in front of the formatting or even after the formatting string
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With