python中的格式化输出and format()应用

普通格式化方法

  1. (%s%d)生成格式化的字符串,其中s是一个格式化字符串,d是一个十进制数;
  2. 格式化字符串包含两部分:普通的字符和转换说明符(见下表),

    将使用元组或映射中元素的字符串来替换转换说明符;

    **如果d是元组的话,必须与s中的转换说明符个数一致; 
    如果d是dict的话,每个转换说明符都必须与dict中一个有效的键名相关联.**

转换说明符,都以%开始 输出格式
d,i 十进制
u 无符号数
o 八进制
x 十六进制或长整数
X 十六进制
f,e,E 浮点数
g,G 指数小于-4时使用
s 字符串或者任意对象,同str生成的字符串
r 同repr生成的字符串

3. 在%字符和转换字符之间,可以出现以下修饰符,并且只能按照以下顺序出现,

  1. 位于括号中的一个键名,用于从dict中获取这个key对应的值,如果不存在key,则引发异常;
  2. 下面中的一个或者多个: 
    • -,左对齐标志,默认为右对齐;
    • +,表示应该包含数字的正负号;
    • 0,表示用0来填充;
  3. 指定最小自动宽度的数字.转换后的值将被打印在至少为这个宽度的字符串中,并且在左边填充空格至满字段宽(如果指定了-标志,则在右边填充);(如果字符串本身的长度大于指定宽度,则这个宽度就没用啦).
  4. 一个小数点,用于按照精度分割字段宽度;
  5. 一个数字,指定要打印字符串中最大字符个数,浮点数中小数点之后的位数或整数的最小位数;
  6. *用于任意宽度的字段中替换数字.如果存在,宽度将从元组的下一项开始读取;(有点晕啊- -,结合下面代码看就容易理解了)
     1 #!/usr/bin/python
     2
     3
     4 # -*- coding: utf-8 -*-
     5
     6
     7 #1
     8
     9 a = {"name":‘ljs‘,"age":22,‘weight‘:75}
    10 print "%(name)s %(age)d %(weight)d;"%a  #ljs 22 75;
    11
    12
    13 #将已经定义的变量扩展到字符串中
    14
    15 name = ‘ljs‘
    16 age = 22
    17 weight = 75
    18 r = "%(name)s %(age)d %(weight)d;"%vars()
    19 print r              #ljs 22 75;
    20 print vars()         #vars()函数包含一个此时已定义的所有变量的字典
    21
    22
    23 #2 and 3
    24
    25 a = ‘abc‘
    26 b = 100
    27 c = -100
    28 print "%d"%(a,b)     #error
    29 print "%10s ;"%a     #       abc ;最小宽度为10,宽度不足10,默认为右对齐,向左补充空格直至宽度为10
    30 print "%-10s ;"%a    #abc        ;最小宽度为10,宽度不足10,-为左对齐标志,向右补充空格直至宽度为10
    31 print "%+10s ;"%a    #       abc ;字符串没有符号,so 标志+ 不起作用
    32 print "%010s ;"%a    #       abc ;不是数字,不用填充0,所以标志0不起作用
    33 print "%10d ;"%b     #       100 ;最小宽度为10,宽度不足10,默认为右对齐,向左补充空格直至宽度为10
    34 print "%-10d ;"%b    #100        ;最小宽度为10,宽度不足10,-为左对齐标志,向右补充空格直至宽度为10
    35 print "%+10d ;"%b    #      +100 ;打印出符号
    36 print "%+10d ;"%c    #      -100 ;打印出符号
    37 print "%+010d ;"%b   #+000000100 ;填充0至宽度为10
    38
    39
    40 #4 5
    41
    42 a = 1.23456
    43 print "%f"%a         #1.234560;正常打印
    44 print "%3f"%a        #1.234560;最小宽度为3,但是长度已经超过了3,so正常打印
    45 print "%10f"%a       #  1.234560;最小宽度为10,宽度不足10,默认为右对齐,向左补充空格直至宽度为10
    46 print "%.3f"%a       #1.235;小数点后的数字为精度,小数点后保留3位
    47 print "%.10f"%a      #1.2345600000;小数点后位数不足10,补0至位数为10
    48
    49
    50 #6
    51
    52 a = 123456.7890123456
    53 print "%*.*f;"%(15,5,a) #   123456.78901;第一个*为最小宽度,第二个*为小数点后面的精度
    54 print "%-*.*f;"%(15,5,a)#123456.78901   ;

高级字符串格式化

  1. 字符串的format()函数,该方法收集位置参数和关键字参数的任意集合,并使用它们的值来替换字符串中的占位符;
  2. 形式为{n}(n为整数)的占位符将被format()方法第n个参数所代替;

    形式为{name}的占位符将被参数中为name的参数所替代;

    如果要用format()输出{xx},必须使用{{xx}},否则会因为找不到对应的参数值而报错;

  3. 可以指定格式说明符,对输出进行更加精确地控制.

    给每个占位符添加可选的格式说明符号,如{name:format_spec}.这种说明符可指定列宽,小数位和对齐方式.

    一般格式[fill,align,sign,0,width,.precision,type],每一处都是可选的.

    • fill:是一个可选的填充字符,用于填充空白,默认为空格;
    • align,对齐方式.<,>,^分别代表左,右,居中对齐,默认为右对齐;
    • sign,取值为: 
      1. +,所有数字签名都要加上符号;
      2. -,默认值,只在负数签名加符号;
      3. 空格,在正数前面加上一个空格;
    • 0,在宽度前面加0表示用0来填充数值前面的空白;
    • width,宽度;
    • .precision,精度的位数;
    • type,数据类型,如d(整数),s(字符串)等
  4. 某些情况下,可能只是要格式化对象的str()或repr()表示,需要绕过__format__()方法.为此,可以在格式说明符前面添加!r或!s说明符,如果不懂见下面代码.
 1 #!/usr/bin/python
 2 # -*- coding: utf-8 -*-
 3 ‘‘‘
 4 help(str.format)
 5 Help on method_descriptor:
 6
 7 format(...)
 8     S.format(*args, **kwargs) -> string
 9
10     Return a formatted version of S, using substitutions from args and kwargs.
11     The substitutions are identified by braces (‘{‘ and ‘}‘).
12 ‘‘‘
13 print "{{a}}".format()                   #{a}
14 print "{a}".format()                     #error,里面没有为a的参数
15 print "{a} - {b}".format(a = 100,b = 200)#100 - 200
16 print "{0},{0}".format(11,22)            #11,11
17 print "{0},{0},{1},{2}".format(11,22,33) # 11,11,22,33  中括号里面的数代表第几个参数
18 print "{0:3d},{1:4s},{1:5s},{2}".format(11,"a",33) # ‘ 11,a   ,a    ,33‘
19
20 print "{0:=>+011.3f};".format(12.12345)  #====+12.123;用=来填充,右对齐,因为已经用=来填充了,0无效,宽度11,小数点精度后精度为3,类型为浮点数
21 print "{0:>+011.3f};".format(12.12345)   #0000+12.123;
22 

23 a = "test"
24 print "{0:^10}".format(a)                #test
25 print "{0!s:^10}".format(a)              #test
26 print "{0!r:^10}".format(a)              #‘test‘
27
28 #通过下标也行
29 a=[1,2]
30 print ‘{0[0]},{0[1]}‘.format(a)          #1,2
31
32 #对象属性
33 class Test(object):
34     def __init__(self,name,age):
35         self.name,self.age = name,age
36
37     def __str__(self):
38         return ‘This boy is {self.name},is {self.age} old‘.format(self=self)
39
40     def str(self):
41         return self.__str__()
42 a = Test(‘lilei‘,12)
43 print str(a)    #This boy is lilei,is 12 old
44 print a.str()   #This boy is lilei,is 12 old
45
46 #format函数单独使用
47 format(‘abc‘,"10s")     #‘abc       ‘

总而言之,将format()里面的参数视为一个正常的参数,这个对象该有的属性在字符串(s.format()中的 s )里面也能使用!!!

时间: 2024-10-06 06:16:56

python中的格式化输出and format()应用的相关文章

Python中print格式化输出

截取字符串输出,下面例子将只输出字符串的前3个字母 >>> str="abcdefg" >>> print "%.3s" % str abc 按固定宽度输出,不足使用空格补全,下面例子输出宽度为10 >>> str="abcdefg" >>> print "%10s" % str abcdefg 截取字符串,按照固定宽度输出 >>> st

python中字符串格式化%与.format

Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This PEP proposes a new system for built-in string formatting operations, intended as a replacement for the existing '%' string formatting operator. 1.百分号

Python格式化输出字符串 (%, format(), f&#39;&#39;)

格式说明符/占位符:% 目的:格式与内容分离,制作复杂的公共字符串模板,让某些位置变成动态可输入的. 用法:' %[datatype]  '  % (data, data, ...) %前设置输出格式,用引号括起来:%后设置输出内容,格式部分有几个%,内容部分就有几个数据,多个数据时用小括号括起来,并用逗号分隔. 需要输出%时,可以用%%转义,就取消了占位符的作用 print('3%%%s' % 'gg') 结果: 3%gg 整型 %o 八进制 ,%d  (或%i)十进制,%x 十六进制 pri

Python中字符串格式化如何实现?

Python开发中字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存. This PEP proposes a new system for built-in string formatting operations, intended as a replacement for the existing '%' string formatting operator. 1.百分号方式 %[(na

python 中简单的输出语句

1 python 中简单的输出语句 #coding:utf-8#输出的是整数,得到的也是整数,用raw_inputusername=raw_input('请输入用户名:')#输出的是整数或者字符串,得到的只是字符串#在终端输入时:python空格.py文件拖入pwd=raw_input('请输入密码:')#两个条件同时成立才执行if username=='lily'and pwd=='abc':print 'login'else:print 'notlogin' 2 利用python定义简单的函

python基础_格式化输出(%用法和format用法)

%用法 1.整数的输出 %o —— oct 八进制%d —— dec 十进制%x —— hex 十六进制 >>> print('%o' % 20) 24 >>> print('%d' % 20) 20 >>> print('%x' % 20) 14 2.浮点数输出 2.1 格式化输出 %f ——保留小数点后面六位有效数字 %.3f,保留3位小数位%e ——保留小数点后面六位有效数字,指数形式输出 %.3e,保留3位小数位,使用科学计数法%g ——在保证

07 python 数字的格式化输出 format(重要)

第七课 数字的格式化输出 format ***** 重点 什么叫数字的格式化呢?我们看一个例子:12.4367 ---> 12.4(保留小数点后1位) ---> 12.44 // 保留小数点后1位 这个就叫做 数字的格式化输出 format函数是用来进行数字可视化,有两个参数参数1:要格式化的数字参数2:格式化字符串 例子 x = 1234.56789 # 保留小数点后2位输出 1234.57 # coding:utf-8 x = 1234.56789 # 保留小数点后2位输出 1234.57

Python中输入和输出(打印)数据

一个程序要进行交互,就需要进行输入,进行输入→处理→输出的过程.所以就需要用到输入和输出功能.同样的,在Python中,怎么实现输入和输出? Python3中的输入方式: Python提供了 input() 内置函数从标准输入读入一行文本,默认的标准输入是键盘. 例如: n = input() print(n) >>>输入Python3 >>>Python3 其中输入的数据以字符串类型进行储存,如果输入数字的话,后续需要转换类型才能进行操作. n = input()pr

格式化输出=========》format 和 %

str.format()  实现格式化输出的功能 s1 = "i am {0},gae{1}".format("alex",18)   普通版,直接输入元祖  按括号里面的位置输入 s2 = "i am {0},age{1}".format(*["alex",18])    用一个星号按顺序提取列表中的元素进行输入 dic = {"name":"alex","gae"