68

I have a question about the default behavior of JavaScript's parseFloat function in different parts of the world.

In the US, if you call parseFloat on a string "123.34", you'd get a floating point number 123.34.

If I'm developing code in say Sweden or Brazil and they use a comma instead of a period as the decimal separator, does the parseFloat function expect "123,34" or "123.34".

Please note that I'm not asking how to parse a different culture's number format in the US. I'm asking does parseFloat in Sweden or Brazil behave the same way it does inside the US, or does it expect a number in its local format? Or to better think about this, does a developer in Brazil/Sweden have to convert strings to English format before it can use parseFloat after extracting text from a text box?

Please let me know if this doesn't make sense.

chumphries
  • 693
  • 1
  • 6
  • 6

5 Answers5

78

parseFloat doesn't use your locale's definition, but the definition of a decimal literal.

It only parses . not ,

I'm brazilian and I have to replace comma with dot before parsing decimal numbers.

parseFloat specification

Alcides Queiroz
  • 9,456
  • 3
  • 28
  • 43
16

No, parseFloat is specified to parse DecimalLiterals, which use the dot as decimal separator. It does not depend on the current environment's locale settings.

Bergi
  • 630,263
  • 148
  • 957
  • 1,375
4

It’s not just Sweden/Brazil. F.ex in US they often add commas in large numbers, like $5,762,325.25.

The parseFloat function essentially deals with decimals, not locale strings.

In general, JavaScript can sometimes convert generic strings/numbers/dates to locale-friendly formats, but not the other way around.

David Hellsing
  • 106,495
  • 44
  • 176
  • 212
1

If you are sure it is in Brasilian format, just convert the number to US format before parsing.

function parseItalianNumber(stringNum) {
    return parseFloat(stringNum.replaceAll(".","").replaceAll(",","."));
}

in Italy we also use . as a thousands separator. This removes any thousands separators, just in case (you do not want many dots around), and then converts the comma to a dot, before calling parseFloat.

FrancescoMM
  • 2,845
  • 1
  • 18
  • 29
1

Complementing the answer given by FrancescoMM, you must use regex for really big numbers. String.replace using string as a parameter will replace only the first occurrence. So 999.999.999,99 becomes 999999.999.99

stringNum.replace(/\./g, "").replace(/\,/g, ".")

Source:

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace