PHP ile KDV Hesaplama
Merhaba PT.
Bir çalışmamda KDV hesaplama durumu ortaya çıktı. KDV dahil tutardan KDV hariç veya KDV hariçten KDV dahil tutarı hesaplama gibi durumlarda küsürat sorunu yaşıyorum.
Burada yaşadığım problem;
$tutar = "100.00";
$kdv = "18";
$sonuc = $tutar / (1 + ($kdv/100));
// SONUÇ: 84.745762711864
SONUÇ'da görünen kısımdaki 74'den sonraki rakamın büyüklüğüne göre yukarı düzlemek (84,75) veya;
$tutar = "101.00";
$kdv = "18";
$sonuc = $tutar / (1 + ($kdv/100));
// SONUÇ: 85.593220338983
Buradaki SONUÇ da görünen 59'dan sonraki kısım aşağıda olduğu için (85.59) sonucu almak istiyorum.
Burada da anladığım kadarıyla dediğim mantıkta yapıyor işlemi.
ceil()
veya round()
gibi fonksiyonları denedim ama noktadan sonraki kısmı direk yuvarlıyor.
NOT: Ürün fiyatını veritabanında decimal(9,2)
şeklinde tutuyorum.
Soru hatalı mı? 👎
Eğer sorunun kurallara aykırı olduğunu düşünüyorsanız lütfen bize bildirin!
Cevaplar (3)
Kodunuzu şu şekilde düzelterek istediğiniz sonuca ulaşabilisiniz!
<?php
function kdvsizTutar($tutar, $kdv) {
$sonuc = $tutar / (1 + ($kdv/100));
return number_format($sonuc, 2, '.', '');
}
$kdv = "18";
$tutar = "100.00";
echo kdvsizTutar($tutar, $kdv); // 84.75
$tutar = "101.00";
echo kdvsizTutar($tutar, $kdv); // 85.59
@serkan hocam number_format()
fonksiyonunu biliyorum fakat bu fonksiyon 1000'li rakamlarda noktalama da yapıyor. İşin özünde yukarda belirttiğim gibi decimal(9,2) şeklinde veritabanında tutarken zaten kendi istediğim işlemi yapıyor. Sepette ve sipariş detayında doğru rakamları gösterebilmek için aslında bu çabaya girdim. number_format()
ile çözeceğim gibi görünüyor. Teşekkür ederim. :)
$tutar = "101.00";
$kdv = "18";
$sonuc = number_format($tutar / (1 + ($kdv/100)),2);
echo $sonuc; //85.59
aradığın şey bu sanırsam
---------- buda javascript ile ---------
var tutar=101.00;
var kdv =18;
var sonuc =tutar / (1 + (kdv/100))
var sonuc = sonuc.toFixed(2)
alert(sonuc); //85.59