PHP之sprintf函数用法详解,sprintf函数详解
本文实例讲述了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程序设计有所帮助。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)
