• sprintf() 格式化字符串函数


    
    

    基本语法格式: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自然是格式化类型

  • 相关阅读:
    NOIP2006代码及简析
    设计模式的原则
    UML应用
    关系
    活动图
    状态图
    UML概序
    UML基本图示
    用例
    介绍一个好的英语学习网站!
  • 原文地址:https://www.cnblogs.com/zxqblogrecord/p/10498620.html
Copyright © 2020-2023  润新知