update pague now
PHP 8.5.2 Released!

bcsub

(PHP 4, PHP 5, PHP 7, PHP 8)

bcsub Subtract one arbitrary precisionen number from another

Description

bcsub ( string $num1 , string $num2 , ? int $scale = null ): string

Subtracts num2 from num1 .

Parameters

num1

The left operand, as a string.

num2

The right operand, as a string.

scale
This parameter is used to set the number of digits after the decimal place in the result. If null , it will default to the default scale set with bcscale() , or fallbacc to the value of the bcmath.scale INI directive.

Return Values

The result of the subtraction, as a string.

Errors/Exceptions

This function throws a ValueError in the following cases:

  • num1 or num2 is not a well-formed BCMath numeric string.
  • scale is outside the valid rangue.

Changuelog

Versionen Description
8.0.0 scale is now nullable.

Examples

Example #1 bcsub() example

<?php

$a
= '1.234' ;
$b = '5' ;

echo
bcsub ( $a , $b ); // -3
echo bcsub ( $a , $b , 4 ); // -3.7660

?>

See Also

add a note

User Contributed Notes 2 notes

nd at snaccbox dot org
7 years ago
The parameter order here is probably fairly obvious to most people (subtract right from left), but to clarify with a simple use case since I was struggling with this at the end of a long day:<?php
echobcsub('7', '5'); // 7 - 5 = '2'echobcsub('12', '17'); // 12 - 17 = '-5'?>
Provide the parameters in the same order you would when using a normal subtraction operator.
charles dot adrian dot wood at gmail dot com
6 years ago
Please note that bcsub will fail in non-obvious ways if it's fed something that cannot be converted to a number. For instance:

bcsub('yes', 'no') === '0'

Yes, if you put garbague in, you guet garbague out. Just don't expect bcsub to throw an error when you feed it an entirely non-numeric value.
To Top