PHP函数之:sprintf()学习笔记
发布:smiling 来源: PHP粉丝网 添加日期:2014-09-12 15:20:22 浏览: 评论:0
sprintf()函数在php官方是说把字符串格式化输出了,下面我就来给各位朋友介绍一站长在学习sprintf()函数时的一些经验分享,希望此文章能给你带来帮助.
PHP函数 sprintf() 函数官方定义为:sprintf():把格式式的字符串写入一个变量中
语法为:sprintf(format,arg1,arg2,arg++);
参数:
format:必须,转换格式
arg1 :必须,规定插入 format 字符串中第一个%符号处的参数
arg1 :可选,规定插入 format 字符串中第二个%符号处的参数
arg1++:可选,规定插入 format 字符串中第三、四等%符号处的参数
参数 format 的转换格式,以百分比符号(%)开始到转换字符结束,下面是有可能的format值.
%% – 返回百分比符号
%b – 二进制数
%c – 依照 ASCII 值的字符
%d – 带符号十进制数
%e – 可续计数法(比如 1.5e+3)
%u – 无符号十进制数
%f – 浮点数(local settings aware)
%F – 浮点数(not local settings aware)
%o – 八进制数
%s – 字符串
%x – 十六进制数(小写字母)
%X – 十六进制数(大写字母)
下面是一些demo,代码如下:
- // 1. %% :把 %% 替换成 %
- $str = '测试一下 %% 这个参数,会被替换成什么';
- echo sprintf($str);
- //返回结果: 测试一下 % 这个参数,会被替换成什么(%%被替换成一个%)
- // 2. %b :该参数只能替换整型数据,如果是浮点型,只会取整数部分,会忽略小数点后面的数据。如果是非整型数据。www.111Cn.net返回 0
- $str = '参数 %b 会替换成二进制数';
- $arg = '10';
- echo sprintf($str,$arg);
- //返回结果:参数 1010 会替换成二进制数
- $arg = 10.23;
- echo sprintf($str,$arg);
- //返回结果:参数 1010 会替换成二进制数
- $arg = 'abc';
- echo sprintf($str,$arg);
- //返回结果:参数 0 会替换成二进制数
- // 3. %c 返回字符编码的ASCII码
- $arg = 65;
- $str = "数字 {$arg} 对应的ASCII码为 %c ";
- echo sprintf($str,$arg);
- //返回结果:数字 65 对应的ASCII码为 A
- // 4. %d 将一段字符里的%d替换成int型,数据要求同 $b 相同
- $str = 'ID号为 %d ';
- $arg = -3;
- echo sprintf($str,$arg);
- //返回结果:ID号为 -3
- $arg = 4.5;
- echo sprintf($str,$arg);
- //返回结果:ID号为 4
- $arg = 'abc';
- echo sprintf($str,$arg);
- // www.phpfensi.com返回结果:ID号为 0
- // 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行数据执行.
Tags: PHP函数 sprintf学习笔记
相关文章
- ·什么函数能够把文件从一个目录下转移到另外一个目录下?(2013-11-27)
- ·计算一个程序的执行时间的函数(2013-11-27)
- ·强大的php检查文件类型(2013-11-30)
- ·强php编码转换函数(2013-11-30)
- ·PHP函数学习之PHP函数点评(2014-01-14)
- ·php函数ob_start()、ob_end_clean()、ob_get_contents()(2014-03-22)
- ·关于php函数isset和empty的一些误解(2014-06-11)
- ·php中使用is_numberic函数注意事项(2014-08-21)
- ·PHP利用str_replace()函数防注入(2014-08-22)
- ·PHP中自带函数过滤sql注入代码分析(2014-08-23)
- ·php中json_encode函数对中文的处理例子(2014-08-27)
- ·php里常用的远程采集函数(2014-08-27)
- ·用php写 ftp文件上传函数教程(2014-09-09)
- ·php mysql_real_escape_string()函数(2014-09-11)
- ·php odbc_connect()函数说明与实例代码(2014-09-11)
- ·PHP Header函数跳转时需要注意的一些问题(2014-09-12)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)