// 5. %s - 字符串 $str = "这是用来测试的sprintf的字符串( %s )。今天消费了%f元。从钟楼到小寨有%d站。上班"; $arg = '%s'; echo sprintf($str,$arg,6,5); //返回结果:这是用来测试的sprintf的字符串( %s )。今天消费了6.000000元。从钟楼到小寨有5站。上班 至于其它的参数,大家可以试着测试一下.下面说一下这个函数的一些用途,比如我们在对一张数据表所有数据做多个字段更新时,如果使用循环更新的话,那是很耗费资源的,这里就要用到我们sprintf()函数了.在数据库批量更新时,我一般采用 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教程