Solved

Java and Currency Counting

Posted on 2011-02-18
13
336 Views
Last Modified: 2012-05-11
Hi Experts,

I want to count a set of numbers that happen to be in EUR format (not USD).
3,45 translates to 3.45 in US

I want to count a bunch of numbers that are in EUR format.  Can anyone offer any tips on how to do this?
Ex:
345,99
200,99
567,83
Total = 1.114,81

I know that BigDecimal will blow up if I use commas so I'm not sure what else to use.  

Thank you!!
0
Comment
Question by:Greengiants15
  • 9
  • 3
13 Comments
 
LVL 47

Expert Comment

by:for_yan
ID: 34931077
You just use replace before you use big decimal
String s1 = s.replace(",",".")
is this tyour question?
0
 
LVL 47

Expert Comment

by:for_yan
ID: 34931099
Or maybe even better:

     String s = "1.114,81";
       
        String s1 = "";
        for(int j=0; j<s.length(); j++){
            if(s.charAt(j)== '.')continue;
            if(s.charAt(j)==',')s1 = s1 + ".";
            else s1 = s1 + s.charAt(j);


        }
        System.out.println(s1);
it should print:
 1114.81
0
 
LVL 47

Expert Comment

by:for_yan
ID: 34931103
If you want then to use them as numbers
you can after that use

double x =  Double.parseDouble(s1);
0
 
LVL 47

Expert Comment

by:for_yan
ID: 34931119
You can of course make a method out of it:

String convert(String s){
    String s1 = "";
        for(int j=0; j<s.length(); j++){
            if(s.charAt(j)== '.')continue;
            if(s.charAt(j)==',')s1 = s1 + ".";
            else s1 = s1 + s.charAt(j);
 
        }
      return s1;
}

then you just sum them like

double sum;

sum += Double.parseDouble(convert(s)); - add for each number




0
 
LVL 92

Assisted Solution

by:objects
objects earned 250 total points
ID: 34931131
0
 

Author Comment

by:Greengiants15
ID: 34931174
Thanks objects and for Yan - once I know the currency, then are you saying I should so a String.replace() on the commas?  It there not an easier way to calculate this?
0
3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

 
LVL 92

Expert Comment

by:objects
ID: 34931193
NumberFormat should handle it for you
0
 
LVL 47

Expert Comment

by:for_yan
ID: 34931195
I'm not sure it all depends on currency - it rather depends on the country - on Locale - in some
countries they use commas, in some they do not use.
If your numbers come from different countries, then, i guess you should use
the way onjects suggested bu specify locale. If all your numbers are
uniform in sense of the country like that 1.111,18 then you can
use method which I wrote (replace is not enough - it will not remove the dot).
0
 
LVL 92

Expert Comment

by:objects
ID: 34931217
actually your values aren't actually currency values, they are just numbers.
you should just need to specify locale to use for parsing
0
 
LVL 47

Expert Comment

by:for_yan
ID: 34931237
@objects:
Still, this throws exception for me in Java 1.5:
 
NumberFormat format = NumberFormat.getCurrencyInstance(Locale.FRANCE);
         Object value = format.parse("5,45");
       
0
 
LVL 47

Expert Comment

by:for_yan
ID: 34931244
@objects:
Yes without curreny it works:

NumberFormat format = NumberFormat.getInstance(Locale.FRANCE);
         Object value = format.parse("5,45");
       
0
 
LVL 47

Expert Comment

by:for_yan
ID: 34931254
But this returns just "1", rather than "1115.45"
 
  NumberFormat format = NumberFormat.getInstance(Locale.FRANCE);
         Object value = format.parse("1.115,45");
       
        System.out.println("value: " + value);
0
 
LVL 47

Accepted Solution

by:
for_yan earned 250 total points
ID: 34931280

This works for both 5,45 and 1.115,45:

    NumberFormat format = NumberFormat.getInstance(Locale.GERMANY);
         Object value = format.parse("5,45");
       
        System.out.println("value: " + value);
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Requested array size exceeds VM limit 3 84
Java Loop 6 48
web services creation SOAP vs REST 5 17
java stored proc example 9 19
I had a project requirement for a displaying a user workbench .This workbench would consist multiple data grids .In each grid the user will be able to see a large number of data. These data grids should allow the user to 1. Sort 2. Export the …
Introduction This article is the second of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article covers the basic installation and configuration of the test automation tools used by…
Viewers learn how to read error messages and identify possible mistakes that could cause hours of frustration. Coding is as much about debugging your code as it is about writing it. Define Error Message: Line Numbers: Type of Error: Break Down…
Viewers will learn how to properly install Eclipse with the necessary JDK, and will take a look at an introductory Java program. Download Eclipse installation zip file: Extract files from zip file: Download and install JDK 8: Open Eclipse and …

930 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now