PHP remove commas from numeric strings

PhpStringReplaceNumbersComma

Php Problem Overview


In PHP, I have an array of variables that are ALL strings. Some of the values stored are numeric strings with commas.

What I need:

A way to trim the commas from strings, and ONLY do this for numeric strings. This isn't as straightforward as it looks. The main reason is that the following fails:

$a = "1,435";

if(is_numeric($a))
    $a = str_replace(',', '', $a);

This fails because $a = "1435" is numeric. But $a = "1,435" is not numeric. Because some of the strings I get will be regular sentences with commas, I can't run a string replace on every string.

Php Solutions


Solution 1 - Php

Do it the other way around:

$a = "1,435";
$b = str_replace( ',', '', $a );

if( is_numeric( $b ) ) {
    $a = $b;
}

Solution 2 - Php

Not tested, but probably something like if(preg_match("/^[0-9,]+$/", $a)) $a = str_replace(...)

Solution 3 - Php

The easiest would be:

$var = intval(preg_replace('/[^\d.]/', '', $var));

or if you need float:

$var = floatval(preg_replace('/[^\d.]/', '', $var));

Solution 4 - Php

It sounds like the ideal solution for what you're looking for is filter_var():

$a = filter_var($a, FILTER_VALIDATE_FLOAT, FILTER_FLAG_ALLOW_THOUSAND);

(Note that it's using FILTER_VALIDATE_FLOAT instead of FILTER_VALIDATE_INT because that one doesn't currently have a FILTER_FLAG_ALLOW_THOUSAND option).

Solution 5 - Php

Try this .this worked for me

number_format(1235.369,2,'.','')

if you use number_format like this number_format(1235.369,2) answer will be 1,235.37

but if you use like below

number_format(1235.369,2,'.','') answer will be 1235.37

it's removing the "," of "1,235.37"

Solution 6 - Php

 function cleanData($a) {

     if(is_numeric($a)) {

     $a = preg_replace('/[^0-9,]/s', '', $a);
     }

     return $a;
  
}

Solution 7 - Php

If you want to remove commas from numbers inside a string that also contains words, the easiest way I think would be to use preg_replace_callback:

Example:  

> $str = "Hey hello, I've got 12,500 kudos for you, spend it well"

function cleannr($matches)
{
    return str_replace("," , "" , $matches["nrs"]);
}

$str = preg_replace_callback ("/(?P<nrs>[0-9]+,[0-9]+)/" , "cleannr" , $str);


Output:

> "Hey hello, I've got 12500 kudos for you, spend it well"


In this case the pattern (regex) differs from the one given in the accepted answer since we don't want to remove the other commas (punctuation).

If we'd use /[0-9,]+/ here instead of /[0-9]+,[0-9]+/ the output would be:

> "Hey hello I've got 12500 kudos for you spend it well"

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questionuser1082428View Question on Stackoverflow
Solution 1 - PhpJJJView Answer on Stackoverflow
Solution 2 - PhpKenaniahView Answer on Stackoverflow
Solution 3 - PhpJayelaView Answer on Stackoverflow
Solution 4 - PhporrdView Answer on Stackoverflow
Solution 5 - PhpkaushiView Answer on Stackoverflow
Solution 6 - PhpRyanView Answer on Stackoverflow
Solution 7 - PhpFlaxiousView Answer on Stackoverflow