热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHPsprintf函数使用实例详解与教程

本文详细介绍了PHP中`sprintf`函数的使用方法,并通过具体示例进行说明。例如,使用`%%`作为参数时,`%%`会被替换为`%`。通过`echosprintf($str)`可以验证这一行为,返回的结果是“测试一下%这个参数,会被替换成什么”。此外,文章还探讨了`sprintf`函数在格式化字符串中的多种应用场景,包括数字格式化、日期时间处理等,帮助读者全面掌握该函数的使用技巧。
  1. // 1. %% :把 %% 替换成 %
  2. $str = '测试一下 %% 这个参数,会被替换成什么';
  3. echo sprintf($str);
  4. //返回结果: 测试一下 % 这个参数,会被替换成什么(%%被替换成一个%)
  5. // 2. %b :该参数只能替换整型数据,如果是浮点型,只会取整数部分,会忽略小数点后面的数据。如果是非整型数据。返回 0
  6. $str = '参数 %b 会替换成二进制数';
  7. $arg = '10';
  8. echo sprintf($str,$arg);
  9. //返回结果:参数 1010 会替换成二进制数
  10. $arg = 10.23;
  11. echo sprintf($str,$arg);
  12. //返回结果:参数 1010 会替换成二进制数
  13. $arg = 'abc';
  14. echo sprintf($str,$arg);
  15. //返回结果:参数 0 会替换成二进制数
  16. // 3. %c 返回字符编码的ASCII码
  17. $arg = 65;
  18. $str = "数字 {$arg} 对应的ASCII码为 %c ";
  19. echo sprintf($str,$arg);
  20. //返回结果:数字 65 对应的ASCII码为 A
  21. // 4. %d 将一段字符里的%d替换成int型,数据要求同 $b 相同
  22. $str = 'ID号为 %d ';
  23. $arg = -3;
  24. echo sprintf($str,$arg);
  25. //返回结果:ID号为 -3
  26. $arg = 4.5;
  27. echo sprintf($str,$arg);
  28. //返回结果:ID号为 4
  29. $arg = 'abc';
  30. echo sprintf($str,$arg);
  31. //返回结果:ID号为 0
  32. // 5. %s - 字符串
  33. $str = "这是用来测试的sprintf的字符串( %s )。今天消费了%f元。从钟楼到小寨有%d站。上班";
  34. $arg = '%s';
  35. echo sprintf($str,$arg,6,5);
  36. //返回结果:这是用来测试的sprintf的字符串( %s )。今天消费了6.000000元。从钟楼到小寨有5站。上班

有关参数用法,测试: 在对一张数据表所有数据做多个字段更新时,如果使用循环更新的话,那是很耗费资源的,这里就要用到我们sprintf()函数了。 在数据库批量更新时,一般采用 case then when end 的语法来做,基本语法,例如:

  1. UPDATA table
  2. SET field = CASE id
  3. WHEN 1 THEN 'value1'
  4. WHEN 2 THEN 'value2'
  5. WHEN 3 THEN 'value3'
  6. END
  7. WHERE id IN (1,2,3)

更新 table 设置 id = 1 的值为 value1, id = 2 的值为 value2 ,id = 3 的值为 value3,这样参数上面的函数将sql语句结合成这样SQL语句,只需一条SQL就可以进行批量更新

例子:

  1. //比如 id 对应的值为以下数组
  2. $info = array(1=>'张三',2=>'李四',3=>'王五');
  3. $ids = implode(',',array_keys($info)) //获取所有的ID字符串
  4. //组合SQL
  5. $sql = "UPDATA user SET username = CASE id";
  6. foreach($info as $id=>$username){
  7. $sql .= sprintf("WHEN %d THEN %s",$id,$username);
  8. }
  9. $sql .= "END WHERE id IN ($ids)";
  10. // $model->query($sql)

以上可以完成批量更新的操作,其中where子句确保只有3行数据执行。


推荐阅读
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 在前两篇文章中,我们探讨了 ControllerDescriptor 和 ActionDescriptor 这两个描述对象,分别对应控制器和操作方法。本文将基于 MVC3 源码进一步分析 ParameterDescriptor,即用于描述 Action 方法参数的对象,并详细介绍其工作原理。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
  • Scala 实现 UTF-8 编码属性文件读取与克隆
    本文介绍如何使用 Scala 以 UTF-8 编码方式读取属性文件,并实现属性文件的克隆功能。通过这种方式,可以确保配置文件在多线程环境下的一致性和高效性。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 一个登陆界面
    预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文介绍如何从字符串中移除大写、小写、特殊、数字和非数字字符,并提供了多种编程语言的实现示例。 ... [详细]
  • 本文详细介绍了C语言中的基本数据类型,包括整型、浮点型、字符型及其各自的子类型,并探讨了这些类型在不同编译环境下的表现。 ... [详细]
author-avatar
peteryan
自我学习,提升,早日被动大于主动,实现自由
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有