PHP之sprintf函数用法详解


Posted in PHP onNovember 12, 2014

本文实例讲述了PHP中sprintf函数的用法。分享给大家供大家参考。具体用法分析如下:

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 :该参数只能替换整型数据,如果是浮点型,只会取整数部分,会忽略小数点后面的数据。如果是非整型数据。返回 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);  

//返回结果: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行数据执行.

希望本文所述对大家的PHP程序设计有所帮助。

PHP 相关文章推荐
用PHP的ob_start();控制您的浏览器cache!
Feb 14 PHP
了解Joomla 这款来自国外的php网站管理系统
Mar 11 PHP
php 随机排序广告的实现代码
May 09 PHP
php解决约瑟夫环示例
Apr 09 PHP
PHP zip扩展Linux下安装过程分享
May 05 PHP
CodeIgniter输出中文乱码的两种解决办法
Jun 12 PHP
PHP 只允许指定IP访问(允许*号通配符过滤IP)
Jul 08 PHP
学习php设计模式 php实现单例模式(singleton)
Dec 07 PHP
ajax调用返回php接口返回json数据的方法(必看篇)
May 05 PHP
PHP中用Trait封装单例模式的实现
Dec 18 PHP
详解php反序列化
Jun 10 PHP
phpQuery解析HTML乱码问题(补充官网未列出的乱码解决方案)
Apr 01 PHP
php中simplexml_load_file函数用法实例
Nov 12 #PHP
php实现的ping端口函数实例
Nov 12 #PHP
PHP实现下载断点续传的方法
Nov 12 #PHP
php格式化日期实例分析
Nov 12 #PHP
PHP中的Streams详细介绍
Nov 12 #PHP
PHP产生不重复随机数的5个方法总结
Nov 12 #PHP
php一行代码获取文件后缀名实例分析
Nov 12 #PHP
You might like
淘宝ip地址查询类分享(利用淘宝ip库)
2014/01/07 PHP
php无法连接mysql数据库的正确解决方法
2016/07/01 PHP
Convert Seconds To Hours
2007/06/16 Javascript
用js实现的检测浏览器和系统的函数
2009/04/09 Javascript
可选择和输入的下拉列表框示例
2013/11/05 Javascript
Knockout text绑定DOM的使用方法
2013/11/15 Javascript
js 去掉空格实例 Trim() LTrim() RTrim()
2014/01/07 Javascript
jQuery仿gmail实现fixed布局的方法
2015/05/27 Javascript
Bootstrap基本插件学习笔记之按钮(21)
2016/12/08 Javascript
对象不支持indexOf属性或方法的解决方法(必看)
2017/05/28 Javascript
深入浅析var,let,const的异同点
2018/08/07 Javascript
如何在vue里面优雅的解决跨域(路由冲突问题)
2019/01/20 Javascript
小程序开发踩坑:页面窗口定位(相对于浏览器定位)(推荐)
2019/04/25 Javascript
nodejs实现用户登录路由功能
2019/05/22 NodeJs
原生JS实现留言板
2020/03/26 Javascript
vant 自定义 van-dropdown-item的用法
2020/08/05 Javascript
Python编程实战之Oracle数据库操作示例
2017/06/21 Python
python安装Scrapy图文教程
2017/08/14 Python
pygame库实现俄罗斯方块小游戏
2019/10/29 Python
50行Python代码实现视频中物体颜色识别和跟踪(必须以红色为例)
2019/11/20 Python
用python实现学生管理系统
2020/07/24 Python
Python基础教程之输入输出和运算符
2020/07/26 Python
CSS3中使用RGBA设置透明度的示例
2015/08/04 HTML / CSS
canvas画布实现手写签名效果的示例代码
2019/04/23 HTML / CSS
HTML5 canvas基本绘图之文字渲染
2016/06/27 HTML / CSS
瑞士香水购物网站:Parfumcity.ch
2017/01/14 全球购物
俄罗斯苹果优质经销商商店:iPort
2020/05/27 全球购物
计算机系毕业生推荐信
2013/11/06 职场文书
酒店中秋节活动方案
2014/01/31 职场文书
电气工程及其自动化专业求职信
2014/06/23 职场文书
嘉宾邀请函
2015/01/31 职场文书
海上钢琴师观后感
2015/06/03 职场文书
生产实习心得体会范文
2016/01/22 职场文书
PyTorch 如何检查模型梯度是否可导
2021/06/05 Python
如何通过一篇文章了解Python中的生成器
2022/04/02 Python
Mysql如何查看是否使用到索引
2022/12/24 MySQL