基本语法格式:sprintf("%格式化类型","$str1","$str2") ;
先别急我会一个个慢慢说
先看一下类型参照表,也就是要转换成什么类型的格式
先举个最简单的案例
案例
1.格式化多个变量
要点:
%s = %符号和后面属性符号(s)总称为插入标记组合,也就是把后面准备进行格式化的值($str1)替换在这个位置
hello = 这个单词就是很多人蒙蔽的地方,告诉你这个什么代表也没有,就单纯的代表一个hello,用于分割或者修饰用,一般用[ %s ]、<%s>这样格式化出来后就直接在标签里
记住,一个%标记符后面只有一个类型属性(比如s),s是什么上面有,以字符串的方式格式化
那么多个值怎么格式化一起呢
%s为一个标记,两个%s%s这样写却是错误的,每个%s必须标记键位,不然我怎么知道都代表格式化后面的哪个$str呢,所以有个特别的语法
%1\$%2\$ 解释:%1表示格式化sprintf("%1\$%2\$",''$str1","$str2")中对应的$str1,那么%2自然表示格式化$str2,\$是代表有多个值准备格式化,所以每个%1和%2或者还有%3的标记后都要加这个符号代表一行中有多个标记,如果只有一个标记就不用\$了占位符了,记住$str2、$str3是可选,也就是可以不格式化这么多
sprintf("%'x13.2f",$c);
这是什么意思,f是浮点数,第一步按照格式 % '(补位值) 宽度值 格式化类型 这三部分,语法之间必须紧挨着不能用空格
必须解释一下何为补位值:就是设定的宽度超出了,用这个值来填上
解释一下,补位值只有设置宽度超出了目标值才能用
所以就是用x补位,13为总宽度,2为小数点后的宽度,f为格式化类型,别急我会解释
' 号(单引号)代表接下来要用补位类型
为什么他能识别x是补位值呢,因为前面有 ' 号,
为什么他能识别哪几位是哪种类型呢,他是这样识别的,按顺序从先从两头的字符开始识别是什么类型,补位值肯定是单数位,不可能一个位置补两个数吧,所以左边第一位x是补位值,右边第一位是格式化类型,然后中间的自然是宽度值
第二,为什么小数点 后还有一个属性 ,因为这是f(浮点型),必须设置小数点后有几位,不能小数后面不能设置了吧,那浮点数意义何在呢
不要觉得烦,每个例子都是浓缩出来的
整数补位
这就是整数补位,还是一样
第一步按照格式 %'(补位值) 宽度值 格式化类型 这三部分
0是补位值 7是宽度值 s自然是格式化类型