zoukankan      html  css  js  c++  java
  • Python入门示例系列17 输入与输出

    Python入门示例系列17 输入与输出

    读取键盘输入


    Python 提供了 input() 内置函数从标准输入(键盘)读入一行文本,默认的标准输入是键盘。返回结果是字符串。

    >>> str = input("请输入:");
    请输入:123
    >>> print(str)
    123

     如果从键盘输入两个数字,并求这两个数字之和,该怎么写程序呢?

    a=input("请输入一个数字 ")
    b=input("请再输入一个数字 ")
    print("求和结果 ", eval(a)+eval(b))

    输出

    只想快速显示变量进行调试,可以用 repr()str() 函数把值转化为字符串。

    f' '

     使用 格式化字符串字面值 ,要在字符串开头的引号/三引号前添加 f 或 F 。在这种字符串中,可以在 { 和 } 字符之间输入引用的变量,或字面值的 Python 表达式。

    >>> name="Sam"
    >>> age=20
    >>> f'{name} is {age} yeas old.'
    'Sam is 20 yeas old.'

    str.format()

    字符串的 str.format() 方法需要更多手动操作。该方法也用 { 和 } 标记替换变量的位置,虽然这种方法支持详细的格式化指令,但需要提供格式化信息。

    示例:

    print("{0},{1},{2}".format(1,2,3))
    print("{2},{1},{0}".format(1,2,3))
    print("{1},{1},{1}".format(1,2,3))
    print("{0:b},{1:x},{2:o}".format(1,12,16))

    结果:

    1,2,3
    3,2,1
    2,2,2
    1,c,20

    标准格式说明符 的一般形式如下:

    format_spec     ::=  [[fill]align][sign][#][0][width][grouping_option][.precision][type]
    fill            ::=  <any character>
    align           ::=  "<" | ">" | "=" | "^"
    sign            ::=  "+" | "-" | " "
    width           ::=  digit+
    grouping_option ::=  "_" | ","
    precision       ::=  digit+
    type            ::=  "b" | "c" | "d" | "e" | "E" | "f" | "F" | "g" | "G" | "n" | "o" | "s" | "x" | "X" | "%"

    各种对齐选项的含义如下:

    选项

    含意

    '<'

    强制字段在可用空间内左对齐(这是大多数对象的默认值)。

    '>'

    强制字段在可用空间内右对齐(这是数字的默认值)。

    '^'

    强制字段在可用空间内居中。

     
    对齐文本以及指定宽度:

    >>> '{:<30}'.format('left aligned')
    'left aligned                  '
    >>> '{:>30}'.format('right aligned')
    '                 right aligned'
    >>> '{:^30}'.format('centered')
    '           centered           '
    

    上面的代码指定输出字符串的宽度为30个字符。

    sign 选项仅对数字类型有效,可以是以下之一:

    选项

    含意

    '+'

    表示标志应该用于正数和负数。

    '-'

    表示标志应仅用于负数(这是默认行为)。

    width 是一个定义最小总字段宽度的十进制整数,包括任何前缀、分隔符和其他格式化字符。 如果未指定,则字段宽度将由内容确定。

    precision 是一个十进制数字,表示对于以 'f' and 'F' 格式化的浮点数值要在小数点后显示多少个数位,或者对于以 'g''G' 格式化的浮点数值要在小数点前后共显示多少个数位。

    '{:20.4f}'.format(123.456789)
    '            123.4568'
    '{:20.4F}'.format(123.456789)
    '            123.4568'

    type 确定了数据应如何呈现。

    可用的字符串表示类型是:

    类型

    含意

    's'

    字符串格式。这是字符串的默认类型,可以省略。

    示例

    '{:30s}'.format("abcde")
    'abcde                         '
    '{:<30s}'.format("abcde")
    'abcde                         '
    '{:>30s}'.format("abcde")
    '                         abcde'
    '{:^30s}'.format("abcde")
    '            abcde        

    可用的整数表示类型是:

    类型

    含意

    'b'

    二进制格式。 输出以 2 为基数的数字。

    'c'

    字符。在打印之前将整数转换为相应的unicode字符。

    'd'

    十进制整数。 输出以 10 为基数的数字。

    'o'

    八进制格式。 输出以 8 为基数的数字。

    'x'

    十六进制格式。 输出以 16 为基数的数字,使用小写字母表示 9 以上的数码。

    'X'

    十六进制格式。 输出以 16 为基数的数字,使用大写字母表示 9 以上的数码。 在指定 '#' 的情况下,前缀 '0x' 也将被转为大写形式 '0X'

    示例

    '{:20b}'.format(111)
    '             1101111'
    '{:20d}'.format(111)
    '                 111'
    '{:20o}'.format(111)
    '                 157'
    '{:20x}'.format(111)
    '                  6f'

    floatDecimal 值的可用表示类型有:

    类型

    含意

    'e'

    科学计数法。 对于一个给定的精度 p,将数字格式化为以字母 'e' 分隔系数和指数的科学计数法形式。 系数在小数点之前有一位,之后有 p 位,总计 p + 1 个有效数位。 如未指定精度,则会对 float 采用小数点之后 6 位精度,而对 Decimal 则显示所有系数位。 如果小数点之后没有数位,则小数点也会被略去,除非使用了 # 选项。

    'E'

    科学计数法。 与 'e' 相似,不同之处在于它使用大写字母 'E' 作为分隔字符。

    'f'

    定点表示法。 对于一个给定的精度 p,将数字格式化为在小数点之后恰好有 p 位的小数形式。 如未指定精度,则会对 float 采用小数点之后 6 位精度,而对 Decimal 则使用大到足够显示所有系数位的精度。 如果小数点之后没有数位,则小数点也会被略去,除非使用了 # 选项。

    'F'

    定点表示。 与 'f' 相似,但会将 nan 转为 NAN 并将 inf 转为 INF

    '%'

    百分比。 将数字乘以 100 并显示为定点 ('f') 格式,后面带一个百分号。

     示例

    '{:20.4e}'.format(123.456789)
    '          1.2346e+02'
    '{:20.4E}'.format(123.456789)
    '          1.2346E+02'
    '{:20.4f}'.format(123.456789)
    '            123.4568'
    '{:20.4F}'.format(123.456789)
    '            123.4568'
    '{:20.4%}'.format(123.456789)
    '         12345.6789%'

    格式示例
    按位置访问参数:

    >>> '{0}, {1}, {2}'.format('a', 'b', 'c')
    'a, b, c'
    >>> '{}, {}, {}'.format('a', 'b', 'c')  # 3.1+ only
    'a, b, c'
    >>> '{2}, {1}, {0}'.format('a', 'b', 'c')
    'c, b, a'
    >>> '{2}, {1}, {0}'.format(*'abc')      # unpacking argument sequence
    'c, b, a'
    >>> '{0}{1}{0}'.format('abra', 'cad')   # arguments' indices can be repeated
    'abracadabra'


    按名称访问参数:

    >>> 'Coordinates: {latitude}, {longitude}'.format(latitude='37.24N', longitude='-115.81W')
    'Coordinates: 37.24N, -115.81W'
    >>> coord = {'latitude': '37.24N', 'longitude': '-115.81W'}
    >>> 'Coordinates: {latitude}, {longitude}'.format(**coord)
    'Coordinates: 37.24N, -115.81W'



    访问参数的项:

    >>> coord = (3, 5)
    >>> 'X: {0[0]};  Y: {0[1]}'.format(coord)
    'X: 3;  Y: 5'


    替代 %x 和 %o 以及转换基于不同进位制的值:

    >>> # format also supports binary numbers
    >>> "int: {0:d};  hex: {0:x};  oct: {0:o};  bin: {0:b}".format(42)
    'int: 42;  hex: 2a;  oct: 52;  bin: 101010'
    



    使用逗号作为千位分隔符:

    >>> '{:,}'.format(1234567890)
    '1,234,567,890'



    表示为百分数:

    >>> points = 19
    >>> total = 22
    >>> 'Correct answers: {:.2%}'.format(points/total)
    'Correct answers: 86.36%'



    使用特定类型的专属格式化:

    >>> import datetime
    >>> d = datetime.datetime(2010, 7, 4, 12, 15, 58)
    >>> '{:%Y-%m-%d %H:%M:%S}'.format(d)
    '2010-07-04 12:15:58'


     
     

    REF

    https://docs.python.org/zh-cn/3/tutorial/inputoutput.html

    https://docs.python.org/zh-cn/3/library/string.html#formatspec

    https://www.runoob.com/python3/python3-inputoutput.html

  • 相关阅读:
    win7 x64怎么枚举所有快捷键呢
    C/C++多种方法获取文件大小
    中缀表达式转后缀表达式(逆波兰表达式)
    检测文件存在的四种方法
    透明窗口与不规则窗口制作方法总结
    Struts 2命令执行漏洞
    Windows 8 无法安装
    从浏览器启动客户端程序
    tesseractocr训练方法
    Algorithm Gossip: 中序式轉後序式(前序式)
  • 原文地址:https://www.cnblogs.com/emanlee/p/15816634.html
Copyright © 2011-2022 走看看