PHP之sprintf函数用法详解
《PHP实战:PHP之sprintf函数用法详解》要点: 本篇章节讲解PHP中sprintf函数的用法.分享给大家供大家参考.具体用法分析如下:PHP实战 sprintf()函数在php官方是说把字符串格式化输出了,本文就来给各位朋友介绍一下在学习sprintf()函数时的一些经验分享,希望能给大家带来赞助.PHP实战 PHP函数 sprintf() 函数官方定义为:sprintf():把格式化的字符串写入一个变量中PHP实战 语法为:sprintf(format,arg1,arg2,arg++);PHP实战 参数:PHP实战 format:必须,转换格式PHP实战 arg1 :必须,规定插入 format 字符串中第一个%符号处的参数PHP实战 arg1 :可选,规定插入 format 字符串中第二个%符号处的参数PHP实战 arg1++:可选,规定插入 format 字符串中第三、四等%符号处的参数PHP实战 参数 format 的转换格式,以百分比符号(%)开始到转换字符结束,下面是有可能的format值.PHP实战 %% C 返回百分比符号PHP实战 %b C 二进制数PHP实战 %c C 按照 ASCII 值的字符PHP实战 %d C 带符号十进制数PHP实战 %e C 可续计数法(比如 1.5e+3)PHP实战 %u C 无符号十进制数PHP实战 %f C 浮点数(local settings aware)PHP实战 %F C 浮点数(not local settings aware)PHP实战 %o C 八进制数PHP实战 %s C 字符串PHP实战 %x C 十六进制数(小写字母)PHP实战 %X C 十六进制数(大写字母)PHP实战 下面是一些demo,代码如下:
代码如下:
// 1. %% :把 %% 替换成 %?
$str = '测试一下 %% 这个参数,会被替换成什么';? echo sprintf($str);? //返回结果: 测试一下 % 这个参数,会被替换成什么(%%被替换成一个%)? // 2. %b :该参数只能替换整型数据,如果是浮点型,只会取整数部分,会忽略小数点后面的数据.如果是非整型数据.返回 0? // 3. %c 返回字符编码的ASCII码? 至于其它的参数,大家可以试着测试一下. 下面说一下这个函数的一些用途,比如我们在对一张数据表所有数据做多个字段更新时,如果使用循环更新的话,那是很耗费资源的,这里就要用到我们sprintf()函数了.PHP实战 在数据库批量更新时,我一般采用 case then when end 的语法来做,基本语法如:
代码如下:
UPDATA table?
??? SET field = CASE id? ??????? WHEN 1 THEN 'value1'? ??????? WHEN 2 THEN 'value2'? ??????? WHEN 3 THEN 'value3'? ??? END? WHERE id IN (1,2,3) 上面的意思就是说,更新 table 设置 id = 1 的值为 value1,id = 2 的值为 value2,id = 3 的值为 value3,这样参数上面的函数将sql语句结合成这样SQL语句,只需一条SQL就可以进行批量更新,具体的办法为:
代码如下:
//比如 id 对应的值为以下数组?
$info = array(1=>'张三',2=>'李四',3=>'王五');? $ids = implode(',',array_keys($info)) //获取所有的ID字符串? //组合SQL? $sql = "UPDATA user SET username = CASE id";? foreach($info as $id=>$username){? ???? $sql .= sprintf("WHEN %d THEN %s",$id,$username);? }? $sql .= "END WHERE id IN ($ids)";? // $model->query($sql) 上面就可以完成批量更新的操作,后面的 where子句确保只有3行数据执行.PHP实战 希望本文所述对大家的PHP程序设计有所赞助.PHP实战 《PHP实战:PHP之sprintf函数用法详解》是否对您有启发,欢迎查看更多与《PHP实战:PHP之sprintf函数用法详解》相关教程,学精学透。编程之家 52php.cn为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |