php float浮点型数据应用详解

php教程 float浮点型数据应用详解

1 float round ( float $val [, int $precision ] ) 返回将 val 根据指定精度 precision (十进制小数点后数字的数目)进行四舍五入的结果。precision 也可以是负数或零(默认值)。

     echo round(4.3)  //4

2 string sprintf ( string $format [, mixed $args [, mixed $... ]] ) 返回格式化数据的字符串

view sourceprint?$a=12.338938438; 

echo sprintf("%.5f",$a) //结果:12.33894  

  

  

$a=12.3312356; 

echo sprintf("%.5f",$a);//12.33124 

echo sprintf("%f",$a);//331236  默认小数点后6位

 

3 string number_format ( float $number , int $decimals , string $dec_point , string $thousands_sep )

view sourceprint?$number = 1234.5678; 

  

$english_format_number = number_format($number, 2, '.', ''); 

echo  $english_format_number ; // 1234.57

以上这些都自动做了四舍五入,有时候需求不需要四舍五入呢,怎么办,没有想到好办法,谁知道可以告诉一声。

自己写了个麻烦点的函数,记录下

view sourceprint?function getFloatValue($f,$len) 

  $tmpInt=intval($f); 

  

  $tmpDecimal=$f-$tmpInt; 

  $str="$tmpDecimal"; 

  $subStr=strstr($str,'.'); 

  if(strlen($subStr)<$len+1) 

 { 

  $repeatCount=$len+1-strlen($subStr); 

  $str=$str."".str_repeat("0",$repeatCount); 

  

 } 

  

  return    $tmpInt."".substr($str,1,1+$len); 

  

echo getFloatValue(12.99,4) //12.9900 

echo getFloatValue(12.9232555553239,4) //12.9232

时间: 2024-12-21 06:38:07

php float浮点型数据应用详解的相关文章

SPL3.0数据连接详解

数据|详解 SPL3.0数据连接详解 SPL3.0数据支持能力 SPL3.0在数据连接方面作了很大的改进,使用多种方式对多种数据库进行连接访问,让用户有了更多的选择, 支持的数据库有:SQL Server .Access.Oracle.其他ODBC连接 支持的连接方式有: 用System.Data.SqlClient访问SQL Server 用System.Data.OleDb访问Access和Oracle 用System.Data.Odbc访问SQL Server.Oracle等其他ODBC连

MySQL数据库函数详解(1)

mysql|函数|数据|数据库|详解 (1) int mysql_affected_rows([int link_id]); 在给定的连接中,返回由最近的DELETE.INSERT.REPLACE或者UPDATE语句所作用的行数.如果没有行 被修改,则mysql_affected_rows()返回0,如果出现错误,则返回-1. 在SELECT查询之后,mysql_affected_rows()返回所选择的行数.但一般是与SELECT语句一道使用 mysql_num_rows(). 使用范例: <

MySQL数据库函数详解(2)

mysql|函数|数据|数据库|详解 5) int mysql_data_seek(int result_id, int row_num); 由SELECT查询返回的每个结果集都有一个行游标,指示下一个提取行的函数(mysql_fetch_array().mysql_fetch_object()或者mysql_fetch_row())调用将返回哪一行.mysql_data_seek()将给定结果集的指针设置到给定的行.行号的范围为0到mysql_num_rows()-1.如果行号合法,则mysq

ajax 异步数据操作详解(1/3)

ajax 异步数据操作详解 AJAX全称为"Asynchronous JavaScript and XML"(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术. 主要包含了以下几种技术: Ajax(Asynchronous JavaScript + XML)的定义 基于web标准(standards-based presentation)XHTML+CSS的表示: 使用 DOM(Document Object Model)进行动态显示及交互: 使用 XML

JavaScript处理解析JSON数据过程详解_javascript技巧

JSON (JavaScript Object Notation)一种简单的数据格式,比xml更轻巧. JSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不需要任何特殊的 API 或工具包. JSON的规则很简单: 对象是一个无序的"'名称/值'对"集合.一个对象以"{"(左括号)开始,"}"(右括号)结束.每个"名称"后跟一个":"(冒号):"

以HANA为核心 SAP实时数据平台详解

文章讲的是以HANA为核心 SAP实时数据平台详解,在收购Sybase之前,SAP还不算是个数据库厂商,但其在ERP市场的地位举足轻重.那时的SAP只能通过与其他厂商合作来满足其商务套件的数据库需求,其中最大的合作伙伴就是甲骨文.SAP每年销售约10亿美元的甲骨文数据库,这对于SAP而言就如同在竞争对手的身上撒钱. 由此,Sybase对SAP的意义不言而喻.收购之初,Sybase在全球的数据库业务有超过一万个客户,拥有5%的全球市场占有率,在中国数据库市场这个比例达到18%,被认为是继Oracl

Linux系统下mysqlcheck修复数据库命令(详解)_Mysql

mysqlcheck客户端工具可以检查和修复MyISAM表,还可以优化和分析表. 实际上,它集成了mysql工具中check.repair.analyze.optimize的功能. 有3种方式来调用mysqlcheck: shell> mysqlcheck[options] db_name [tables] shell> mysqlcheck[options] ---database DB1 [DB2 DB3...] shell> mysqlcheck[options] --all--d

【体系结构】Oracle数据块详解

Oracle数据块详解 操作系统块是操作系统读写的最小操作单元,也是操作系统文件的属性之一.当创建一个Oracle数据库时,选择一个基于操作系统块的整数倍大小作为Oracle数据库块的大小.Oracle数据库读写操作则是以Oracle块为最小单位,而非操作系统块. 数据库块也称逻辑块或Oracle块,它对应磁盘上一个或多个物理块,它的大小由初始化参数DB_BLOCK_SIZE决定,可以定义数据块为2K.4K.8K.16K.32K甚至更大,默认Oracle块大小是8K.若一旦设置了Oracle数据

Android json数据解析详解及实例代码

Android json数据解析详解 移动开发经常要与服务器数据交互,也常使用json数据格式,那就说说Android json解析. 1.最简单json格式解析如下: //解析json ry { JSONTokener jsonParser = new JSONTokener(strResult); JSONObject jsonObj = (JSONObject) jsonParser.nextValue(); String strsportsTitle = jsonObj.getStrin