zoukankan      html  css  js  c++  java
  • 变量和格式化输出

    Python采用基于值的内存管理模式。赋值语句的执行过程是:首先把等号右侧表达式的值计算出来,然后在内存中寻找一个位置把值放进去,最后创建变量并指向这个内存地址。Python中的变量并不直接存储值,而是存储了值的内存地址或者引用,这也是变量类型随时可以改变的原因。

    变量用于引用在程序中可能会变化的值。

    1,变量

    In [2]: name1='apple'
    
    In [3]: name2='apple'
    
    In [4]: id(name1)
    Out[4]: 1438115923984
    
    In [5]: id(name2)
    Out[5]: 1438115923984  name1和name2的内存地址一样的 这是Python的内存优化机制
    In [6]: name1="i love you"
    
    In [7]: name2="i love you"
    
    In [8]: id(name1)
    Out[8]: 1438129390000
    
    In [9]: id(name2)
    Out[9]: 1438129393456  此时name1与name2的内存地址就不同了 对长字符串没有内存优化机制
    In [21]: name1=1000
    
    In [22]: name2=1000
    
    In [23]: id(name1)
    Out[23]: 1438129513968
    
    In [24]: id(name2)
    Out[24]: 1438129513616  数字在[-5,257)之间才有内存优化(只开出一个地址空间来)
    
    In [25]: name1=name2=1000
    
    In [26]: id(name1)
    Out[26]: 1438129512784
    
    In [27]: id(name2)
    Out[27]: 1438129512784  连续赋值时就是相当于两个相同的指针指向内存地址,我认为一个钥匙上挂了两个环

    2,格式化输出 字符串格式化输出还是字符形式的

    input()函数的输出默认是字符串格式的

    def format(*args, **kwargs): # real signature unknown
    """
    Return value.__format__(format_spec)

    format_spec defaults to the empty string
    """
    pass


    format(item,format-specifier) item是数字或者字符串,而格式说明符(format-specifier)指定条目item的格式。此函数返回一个字符串。

    例如10.2f  其中10指域宽度     .2指精度   f指转换码    整体就是一个格式符。

    In [32]: format(12.1512345,'10.2f')  
    Out[32]: '     12.15'                         小数点是一位的,默认右对齐,四舍五入
    
    In [33]: format(23.2456453,'10.2f')
    Out[33]: '     23.25'
    
    In [34]: format(12.3,"10.2f")     位数不够补0
    Out[34]: '     12.30'
    
    In [35]: format(23.23456,'.3f')   没有指定宽度根据内容来自动设置的 .n用来指定精度
    Out[35]: '23.235'
    
    In [36]: format(12345678.901,'10.1f')
    Out[36]: '12345678.9'
    
    In [37]: format(12345678.901,'10.2f')  超出了宽度,保证内容优先,增加了宽度
    Out[37]: '12345678.90'
    In [39]: format(585.58558,'10.3e')  科学计数法
    Out[39]: ' 5.856e+02'
    
    In [40]: format(0.0585858,'10.2%') 百分数
    Out[40]: '     5.86%'
    
    In [41]: format(0.5989898,'.3%')
    Out[41]: '59.899%'
    
    In [42]: format(0.0585858,'<10.2%') <左对齐 在格式符的比较前的位置
    Out[42]: '5.86%     '
    In [43]: format(12,'d')  十进制  格式化整数
    Out[43]: '12'
    
    In [44]: format(12,'x')  十六进制
    Out[44]: 'c'
    
    In [45]: format(12,'o')   八进制
    Out[45]: '14'
    
    In [47]: format(12,"b") 二进制
    Out[47]: '1100'
    In [48]: format('we will regain the lost after we lost it','<45s')
    Out[48]: 'we will regain the lost after we lost it     '             指定45为宽度
               
    In [49]: format('we will regain the lost after we lost it','45s') 数字默认右对齐,而字符串是默认的左对齐
    Out[49]: 'we will regain the lost after we lost it     '
    
    In [50]: format('we will regain the lost after we lost it','>45s')
    Out[50]: '     we will regain the lost after we lost it'            对齐方式要和宽度配合用

    %

    In [53]: from math import pi
    
    In [54]: 'pi%i'%pi  i和d都是十进制
    Out[54]: 'pi3'
    
    In [55]: '%.5f'%pi
    Out[55]: '3.14159'
    
    
    In [58]: '%10.3f'%pi
    Out[58]: '     3.142'

    字符串格式化的方法str.format(),基本语法是通过{}和:来代替之前的%

    In [3]: "{}{}".format('hello','world')
    Out[3]: 'helloworld'
    
    In [4]: '{}   {}'.format('hello','world')
    Out[4]: 'hello   world'
    
    
    In [6]: '{1}{0}{0}{1}'.format('hello','world')
    Out[6]: 'worldhellohelloworld'
    
    In [7]: 'name:{name},age:{age}'.format(name="Tom",age="28")
    Out[7]: 'name:Tom,age:28'
    
    
    In [9]: 'name:{name},age:{age}'.format(age="28",name="Tom",)   
    Out[9]: 'name:Tom,age:28'
    In [10]: '{:.2f}'.format(3.1415926)
    Out[10]: '3.14'
    
    In [11]: '{:_}'.format(10000000)
    Out[11]: '10_000_000'
    
    In [14]: "{:^10f}".format(5678.2)
    Out[14]: '5678.200000'
    
    In [15]: "{:>10f}".format(5678.2)  貌似浮点数不好改变位置,貌似字符串的format方法的是左开头 str.format();函数format()是右开头
    Out[15]: '5678.200000'
    
    In [17]: '{:b}'.format(11)
    Out[17]: '1011'
    
    In [20]: "{:x}".format(11)
    Out[20]: 'b'
    In [60]: "{:^10d}".format(12345)
    Out[60]: '  12345   '
    
    In [61]: "{:10d}".format(12345)
    Out[61]: '     12345'
    
    In [62]: "{:<10d}".format(12345)
    Out[62]: '12345     '              整数就是默认的右开头,可以调整位置

    [[fill]align][sign][#][0][width][,][.precision][type]

      • fill           【可选】空白处填充的字符
      • align        【可选】对齐方式(需配合width使用)
        • <,内容左对齐
        • >,内容右对齐(默认)
        • =,内容右对齐,将符号放置在填充字符的左侧,且只对数字类型有效。 即使:符号+填充物+数字
        • ^,内容居中
      • sign         【可选】有无符号数字
        • +,正号加正,负号加负;
        •  -,正号不变,负号加负;
        • 空格 ,正号空格,负号加负;
      • #            【可选】对于二进制、八进制、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示
      • ,            【可选】为数字添加分隔符,如:1,000,000
      • width       【可选】格式化位所占宽度
      • .precision 【可选】小数位保留精度
      • type         【可选】格式化类型
        • 传入” 字符串类型 “的参数
          • s,格式化字符串类型数据
          • 空白,未指定类型,则默认是None,同s
        • 传入“ 整数类型 ”的参数
          • b,将10进制整数自动转换成2进制表示然后格式化
          • c,将10进制整数自动转换为其对应的unicode字符
          • d,十进制整数
          • o,将10进制整数自动转换成8进制表示然后格式化;
          • x,将10进制整数自动转换成16进制表示然后格式化(小写x)
          • X,将10进制整数自动转换成16进制表示然后格式化(大写X)
        • 传入“ 浮点型或小数类型 ”的参数
          • e, 转换为科学计数法(小写e)表示,然后格式化;
          • E, 转换为科学计数法(大写E)表示,然后格式化;
          • f , 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
          • F, 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
          • g, 自动在e和f中切换
          • G, 自动在E和F中切换
          • %,显示百分比(默认显示小数点后6位)
    In [22]: "---{:#^25}".format("water")
    Out[22]: '---##########water##########'
    
    In [32]: "{2:.2f}--{0:,}---{1:<10}".format(12234234,5000,12345.234)
    Out[32]: '12345.23--12,234,234---5000      '

     补充

    In [33]: tp7 = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3], [11, 22, 33])
    
    In [34]: print(tp7)
    i am 1, age 2, really 3
    
    In [35]: tp7 = "i am {1[0]}, age {1[1]}, really {1[2]}".format([1, 2, 3], [11, 22, 33])
    
    In [36]: print(tp7)
    i am 11, age 22, really 33
    
    In [37]: tp7 = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3])
    
    In [38]: print(tp7)
    i am 1, age 2, really 3
    
    In [39]: tp7 = "i am {[0]}, age {[1]}, really {[2]}".format([1, 2, 3])
    Traceback (most recent call last):
    
      File "<ipython-input-39-6064c0aa6d92>", line 1, in <module>
        tp7 = "i am {[0]}, age {[1]}, really {[2]}".format([1, 2, 3])
    
    IndexError: tuple index out of range
     第一个0不能少
    tp1 = "i am {}, age {}, {}".format("seven", 18, 'alex')
    tp2 = "i am {}, age {}, {}".format(*["seven", 18, 'alex'])
    tp3 = "i am {0}, age {1}, really {0}".format("seven", 18)
    tp4 = "i am {0}, age {1}, really {0}".format(*["seven", 18])
    tp5 = "i am {name}, age {age}, really {name}".format(name="seven", age=18)
    tp6 = "i am {name}, age {age}, really {name}".format(**{"name": "seven", "age": 18})
    tp7 = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3], [11, 22, 33])
    tp8 = "i am {:s}, age {:d}, money {:f}".format("seven", 18, 88888.1)
    tp9 = "i am {:s}, age {:d}".format(*["seven", 18])
    tp10 = "i am {name:s}, age {age:d}".format(name="seven", age=18)
    tp11 = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18})
    print(tp1)
    print(tp2)
    print(tp3)
    print(tp4)
    print(tp5)
    print(tp6)
    print(tp7)
    print(tp8)
    print(tp9)
    print(tp10)
    print(tp11)

    1i am seven, age 18, alex
    2i am seven, age 18, alex
    3i am seven, age 18, really seven
    4i am seven, age 18, really seven
    5i am seven, age 18, really seven
    6i am seven, age 18, really seven
    7i am 1, age 2, really 3
    8i am seven, age 18, money 88888.100000
    9i am seven, age 18
    10i am seven, age 18
    11i am seven, age 18
    In [42]: "I am {:.2f} years old".format(*[12.156,34.567])
    Out[42]: 'I am 12.16 years old'
    
    In [43]: "I am {1:.2f} years old".format(*[12.156,34.567])
    Out[43]: 'I am 34.57 years old'

    In [46]: "I am {1[0]:.2f} years old".format([12.156],[34.567])
    Out[46]: 'I am 34.57 years old'
    In [47]: "I am {1[1]:.2f} years old".format([12.156,1,2],[34.567,23.11,345,1])
    Out[47]: 'I am 23.11 years old'

    不涉及形式改变的化,是不用:的
    In [50]: q1=18
    
    In [51]: type(q1)
    Out[51]: int
    
    In [52]: q1='{:d}'.format(18)
    
    In [53]: type(q1)
    Out[53]: str       数字18进过字符串格式化后变成了一个看上去像数字的字符“18”
    In [55]: 'my name is {name2}'.format(**{"name1":"Tom",'name2':"lufy"})
    Out[55]: 'my name is lufy'
    
    In [56]: 'my name is {name2}'.format({"name1":"Tom",'name2':"lufy"})
    Traceback (most recent call last):
    
      File "<ipython-input-56-cbc3db666587>", line 1, in <module>
        'my name is {name2}'.format({"name1":"Tom",'name2':"lufy"})
    
    KeyError: 'name2'   字典必须要加**,我认为啊*从列表降到字符,**从字典降到字符,要么就在format后面的括号中用等号指定
  • 相关阅读:
    PostMan 安装步骤详解
    使用MySQL,运行系统报错Authentication method 'caching_sha2_password' is not supported.
    jmeter安装和环境变量配置
    Svn项目迁移到Git及Visual Studio 中git使用
    SQLServer 2008以上误操作数据库恢复方法
    ABP入门系列之3——创建实体/Code First创建数据表
    ABP入门系列之2——ABP模板项目
    uni-app使用Canvas绘图
    uni-app中picker组件的一个坑
    Nginx用法详解
  • 原文地址:https://www.cnblogs.com/bchy/p/11688915.html
Copyright © 2011-2022 走看看