【基礎】開發中經常用到的4個四捨五入函數

2021-02-19 PHP開源社區

php 在處理浮點數的時候經常要需要用的四捨五入函數。比如在開發訂單中,金額結算,支付,退款等都會涉及到到結算,結算就會用到浮點數類型,偶爾會保留兩位小數,這個時候就會用到四捨五入函數了,以下是對這幾個函數的講解,

floor函數和ceil函數互相搭配起來可以使php 處理的數據更加真實可靠。

floor:捨去取整

ceil:取整,和floor功能相反

round:根據參數選擇精度(這是真正的四捨五入)

intval:獲取變量的整數值,如果參數是字符串,則反回0

看看你使用了哪個函數比較好!

先來看floor函數:

語法:

float floor ( float value )

說明:

返回不大於 value 的下一個整數,將 value 的小數部分捨去取整。floor() 返回的類型仍然是 float,因為 float 值的範圍通常比 integer 要大。

floor() 例子 1

<?php 
 echo floor(1.6); // will output "1" 
 echo floor(-1.6); // will output "-2" 

floor() 例子 2

<?php
echo(floor(0.60));
echo(floor(0.40));
echo(floor(5));
echo(floor(5.1));
echo(floor(-5.1));
echo(floor(-5.9))
?>

輸出:

ceil函數:

語法:

float ceil ( float value )

說明:

返回不小於 value 的下一個整數,value 如果有小數部分則進一位。ceil() 返回的類型仍然是 float,因為 float 值的範圍通常比 integer 要大。

ceil() 例子:

<?php 
echo ceil(4.3);  // 5 
echo ceil(9.999); // 10 
echo ceil(-3.14); // -3 
?>

看到這兩個函數的區別了麼。。

在分頁時我們會常用到的

//頁碼計算:
  $lastpg=ceil($totle/$displaypg); //最後頁,也是總頁數,用ceil就方便多了。
  $lastpg=$lastpg ? $lastpg : 1; //沒有顯示條目,置最後頁為1 
  $page=min($lastpg,$page); 
  $prepg=$page-1; //上一頁 
  $nextpg=($page==$lastpg ? 0 : $page+1); //下一頁 
  $firstcount=($page-1)*$displaypg; 

當然,如果需要制定精度就需要使用round函數了。

round函數:

語法:

float round ( float val [, int precision] )

說明:

返回將 val 根據指定精度 precision(十進位小數點後數字的數目)進行四捨五入的結果。precision 也可以是負數或零(默認值)。

round() 例子

<?php 
echo round(3.4);     // 3 
echo round(3.5);     // 4 
echo round(3.6);     // 4 
echo round(3.6, 0);   // 4 
echo round(1.95583, 2); // 1.96 
echo round(1241757, -3); // 1242000 
echo round(5.045, 2);  // 5.05 
echo round(5.055, 2);  // 5.06 

intval—對變數轉成整數型態

變量轉成整數類型。

語法: int intval(mixed var, int [base]);

返回值: 整數

函數種類: PHP 系統功能
 
內容說明

本函數可將變量轉成整數類型。可省略的參數 base 是轉換的基底,默認值為 10。轉換的變量 var 可以為數組或類之外的任何類型變量。

例子intval()

<?php 
echo intval(4.3); //4 
echo intval(4.6); // 4 
?>

註:intval如果是字符型的會自動轉換為0 如

intval('abc');

輸出結果 0

如果是

intval('5fd');

輸出結果是

5

注:intval不能處理大於9位的數字

以上內容希望幫助到大家,有需要的可以添加下方二維碼進群交流學習新技術。

如果你想和PHP大神交流添加微信,拉你入群

如果你想獲得學習資料添加微信,送你資源

相關焦點

  • EXCEL函數基礎之四捨五入、四捨六入及隨機函數
  • 說說Excel中的四捨五入函數
    基本取整函數包括INT函數、TRUNC函數和ROUND函數。INT函數取整返回小於等於參數number的最大整數。TRUNC函數截尾當省略第二參數或設置為0時,直接捨去小數部分,返回參數的整數部分。ROUND函數四捨五入當指定參數為0時以四捨五入的方式取整。
  • 函數四捨五入使用技巧
    在實際工作的數學運算中,特別是財務計算中常常遇到四捨五入的問題。雖然,excel的單元格格式中允許定義小數位數,但是在實際操作中,我們發現,其實數字本身並沒有真正的四捨五入,只是顯示結果似乎四捨五入了。如果採用這種四捨五入方法的話,在財務運算中常常會出現幾分錢的誤差,而這是財務運算不允許的。那是否有簡單可行的方法來進行真正的四捨五入呢?
  • ROUND(四捨五入)計算指定位數四捨五入某個數字
    ROUND計算指定位數四捨五入某個數字大家好,這節課我們來學習一下Round函數。ROUND,這個函數對於要計算錢的工作崗位尤其重要,人資計算稅金,財務計算工資,經常都會碰到小數點後幾位的數字,一般的做法就是直接在格式裡修改為保留2位小數。但是這個做法會有一個很大的隱患。
  • excel四捨五入函數怎麼用 excel四捨五入函數的使用方法
    首先,選中B1單元格,在B1裡輸入"=round",excel會自動提示四捨五入函數,  雙擊提示出來的ROUND函數,在B1單元格裡就會出現;  然後,單擊A1單元格,輸入逗號,再輸入2(保留兩位小數),  最後,敲回車,即可顯示結果。
  • excel四捨五入函數怎麼用
    真不知道四捨五入是誰發明的,好像小學就開始學習它了,日常買個菜什麼的老闆也不捨得四捨五入最頭省個2,3毛。到時在發工資時常講究個四捨五入,都被公司給摳了。小數點太多了我們都會使用四捨五入的方法來統一保留幾位小數點,這樣也方便計算,一般都是在最後的總數值上進入處理的,不然數據出入就會變得很大了。EXCEL中四捨五入可以使用ROUND函數,ROUND(Number, Num_Digits)按指定的位子對數值進行四捨五入。
  • 四捨五入函數_完整版(建議收藏)
    四捨五入函數_完整版(建議收藏)大家好,今天我們來學習一下四捨五入函數,這類函數很多,如果一個一個的學需要花很多的時間和精力,現在的工作生活節奏飛快
  • excel四捨五入函數是什麼?怎樣使用?
    本篇將介紹excel四捨五入函數是什麼?怎樣使用?有興趣的朋友可以了解一下!一、前言excel是我們生活中很常用的表格製作工具,它不僅僅只是用來製作表格,還可以使用來對表格中的數據進行處理(比如:運算、排序等)。excel對數據的處理也是很強大的,為我們提供了很多函數(比如:求和函數、平均數函數等)。
  • 四捨五入用哪個函數?這5個都可以!
    1、ROUND(要進行捨入的數字,要進行捨入的位數)第二參數為正數時,將數字四捨五入到指定的小數位;第二參數為0時,將數字四捨五入到最接近的整數;第二參數為負數時,則在小數點左側進行四捨五入。本例中用的-2,也就是按照十位的數字進行四捨五入。
  • Excel:乘積求和和四捨五入函數
    數組的個數是2至255個都行。五、ROUND函數——四捨五入函數   我們在財務上計算金額時通常保留至角分,即小數點後兩位數。有時候,有些人表格中的數字從外觀上看,全部是小數點後兩位數,結果造成合計不正確,原因就在於表中的數字只是外觀格式是小數點後兩位數,實際上可能是無窮位數。因此,必要時我們必須對一些數據進行四捨五入,保留我們所需要的位數。
  • 詳細講解Excel中的RAND隨機函數和ROUND四捨五入函數
    七個有趣的Excel函數詳細講解Excel中的RAND隨機函數和ROUND四捨五入函數大家好,今天為大家分享的是Excel中的數學函數,數學是一個偉大的基礎學科,是很多學科發展前進的根基。在Excel中就有幾個常用的數學函數為我們解決了一些常用,但又不能忽視的問題。例如用隨機函數彌補數據不足,用四捨五入函數解決數值的精準程度。下面就逐一講解這幾個函數給大家。1、RAND隨機函數功能:產生一個大於0,小於1的均勻分布的隨機數。
  • Excel四捨五入及數據取整應該知道的3類函數
    那麼Excel數據取整到底怎麼用,今天教大家學習一下工作中最常見的3個函數,讓你知道取整也可以玩出很多花樣,職場中數據應該怎麼來體現。一、INT函數向下取整INT函數為向下取整函數,如圖中所示:函數=INT(B4)=12;函數=INT(B5)=-13;在正數取整的時候,忽略後面的小數位,直接提取前面的整數值;負數取整的時候,會按照小數點前面的負數正數向下提取一位
  • php四捨五入函數(floor、ceil、round與intval)
    本文講述了在php 中處理浮點數時經常要需要用的四捨五入函數。在php 中有兩個函數適用於這種情況:floor函數、ceil函數和round函數floor函數和ceil函數互相搭配起來可以使php 處理的數據更加真實可靠。
  • 職場Excel必備函數——四捨五入函數ROUND & TEXT
    在職場工作中,會遇到用EXCEL處理數字的場景,需四捨五入
  • Excel表格中的四捨五入函數如何使用呢?
    Excel表格中的四捨五入函數如何使用呢?說到四捨五入相信大家都不陌生,讀書的時候都學過,都知道怎麼用,那麼用Excel表格函數怎麼對數據做四捨五入呢?用哪個函數可以做到四捨五入的結果呢?下面小編就簡單介紹一下Excel表格中的四捨五入函數如何使用,希望能幫到您。
  • Excel中如何設置「一舍二入」與「四舍六舍五單雙」的取捨方法
    一、一舍二入取捨的取捨方式在實際的工作中,四捨五入是經常會被用到的取捨方式,但是在一些特定的環境下,對於其他的一些取捨方式就會被用到
  • ASP裡面的四捨五入函數Round和FormatNumber
    ASP中其實有兩個可以用作四捨五入的函數:Round函數和FormatNumber函數。Round 函數返回按指定位數進行四捨五入的數值。數值表達式 被四捨五入。Numdecimalplaces可選項。數字表明小數點右邊有多少位進行四捨五入。如果省略,則 Round 函數返回整數。FormatNumber函數FormatNumber(Expression [, Digit [, LeadingDigit [, Paren [, GroupDigit]]]]。
  • 巧用WPS移動版組合函數四捨五入保留兩位小數
    平時用WPS移動版編輯表格時發現,在統計數據過程中,很多情況下要將數字四捨五入到小數點後兩位小數。利用「單元格格式設置」則不能實現四捨五入。在WPS移動版中,要將數字自動四捨五入,需要使用Round 函數,其公式為:Round (number, num_digits),即指返回按指定位數進行四捨五入的數值。一起來學習吧。
  • Excel:三個四捨五入函數的區別
    除了最常用的ROUND 函數,另外還有向下、向上捨入的ROUNDDOWN、ROUNDUP函數,下面示例清晰地展示出區別,可以應用於不同的需求。一、ROUND 函數是最常用的四捨五入函數01語法ROUND(number, num_digits
  • 因四捨五入造成的誤差怎麼辦?——FIXED函數
    對於財務人員來說,差個0.01都會很煩惱。為了避免因四捨五入面造成的金額誤差,可以使用FIXED函數來避免誤差,從而提高工作效率。例如下列數據:6月、7月數據為自動四捨五入的,相加金額與合計並不相符此時可以用FIXED函數:將數字按指定的小數位數進行取整。