python(二)基础语法-input与print的用法


使用软件为Windows下的vscode。

一.input()函数

1.函数说明

  • 函数在库中的原型及解释说明如下
def input(prompt: Any=...)
'''
Read a string from standard input. The trailing newline is stripped.
The prompt string, if given, is printed to standard output without a trailing newline before reading input.
If the user hits EOF (*nix: Ctrl-D, Windows: Ctrl-Z+Return), raise EOFError. On *nix systems, readline is used if available.
'''
  • 函数接受一个标准输入数据,返回为 string 类型。
  • 函数的参数可选,如果填写,则在接收字符串的时候会打印提示。
  • 回车标志着输入结束,但是回车不会被输入到接收数据的变量中
  • 函数使用格式
data = input()  # 从键盘获取字符,以回车结束

2.函数使用

2.1 数据输入

data = input()  # 输入数据
print(data)     # 打印输入的数据
print(type(data))  # 打印输入的数据类型
print(len(data))   # 打印输入字符串的长度

2.2 带提示的数据输入

data = input("Please enter your data:")  # 输入数据
print(data)     # 打印输入的数据
print(type(data))  # 打印输入的数据类型
print(len(data))   # 打印输入字符串的长度

二.print()函数

1.函数说明

  • 函数在库中的原型及解释说明如下
def print(*values: object, sep: Optional[Text]=..., end: Optional[Text]=..., file: Optional[_Writer]=..., flush: bool=...)
'''
Prints the values to a stream, or to sys.stdout by default. Optional keyword arguments: 
file: a file-like object (stream); defaults to the current sys.stdout. 
sep: string inserted between values, default a space. 
end: string appended after the last value, default a newline. 
flush: whether to forcibly flush the stream.
'''

2.函数使用

2.1 多种变量类型输出

data1 = "hello word!"    # 字符串类型数据
print(data1)
data2 = 999              # 整型数据
print(data2)
data3 = 3.14             # 浮点型数据
print(data3)
data4 = (1, 2, 3)        # 元组数据
print(data4)
data5 = ["a", "b", "c"]  # 列表类型数据
print(data5)
data6 = {"key1": 123, "key2": "abc"}  # 字典类型数据
print(data6)

2.2 格式化输出

  • 格式化输出格式
格式符号转换
%c格式化字符及其ASCII码
%s通过str() 字符串转换来格式化
%i有符号十进制整数
%d有符号十进制整数
%u无符号十进制整数
%o无符号八进制整数
%x无符号十六进制整数(小写字母)
%X无符号十六进制整数(大写字母)
%e用科学计数法格式化浮点数
%E作用同%e,用科学计数法格式化浮点数
%f浮点数字,可指定小数点后的精度
%g%f和%e 的简写
%G%f和%E的简写
%p用十六进制数格式化变量的地址
  • 辅助功能
格式符号功能
*宽度或者小数点精度
-左对齐
+在正数前面显示加号( + )
#在八进制数前面显示零(‘0’),在十六进制前面显示’0x’或者’0X’(取决于用的是’x’还是’X’)
0显示的数字前面填充’0’而不是默认的空格
  • 输出实例1
# 打印字符串长度
print("The length of [%s] is %d bytes" % ("hello world!", len("hello world!")))
  • 输出实例2
pi = 3.141592653
print("pi = %-10.4f" % (pi))  # 宽10字节,精度3位小数,左对齐
print("pi = %+10.4f" % (pi))  # 宽10字节,精度3位小数,默认右对齐,显示"±"号
print("pi = %08.4f" % (pi))   # 宽10字节,精度3位小数
print("pi = %.*f" % (3, pi))  # 用*从后面的元组中读取字段宽度或精度

2.3 format格式化输出

  format把字符串当成一个模板,通过传入的参数进行格式化,并且使用大括号"{}“作为特殊字符代替”%",功能相对于%格式化输出更为强大。

  • 函数原型如下
def format(*args: object, **kwargs: object)
'''
Return value.format(format_spec)
format_spec defaults to the empty string. 
See the Format Specification Mini-Language section of help('FORMATTING') for details.
'''
  • 2.3.1 基本输出方式
print("{} {}".format("hello", "world"))    # 不带任何参数
print("{0} {1}".format("hello", "world"))  # 带数字编号,数字编号指定顺序

print("{0} {1} {0}".format("hello", "world"))  # 打乱顺序
print("{2} {1} {0}".format("hello", "world", "hk"))

print("{a} {b} {a}".format(b="hello", a="world"))  # 带关键字指定相应的字符串
  • 2.3.1 对齐与小数取位数操作
符号功能
<(默认)左对齐
>右对齐
^中间对齐
{:4s}输出占4个字节
{:.2f}输出两位小数
print("{} && {}".format("hello", "world"))  # 默认左对齐

print("{:15s} && {:>15s}".format("hello", "world"))  # 15字节输出,第一个默认左对齐,第二个右对齐
# 注意这里要想在前边加补齐符号,不能省略默认的左对齐符号
print("{:=<15s} && {:=>15s}".format("hello", "world"))  # 15字节输出,第一个默认左对齐,第二个右对齐,不足的用=补齐
print("{:=^10s} && {:=^10s}".format("hello", "world"))  # 10字节中间对齐输出,不足的字节补=

print("{} is {:.3f}".format(3.1415926, 3.1415926))  # 保留2位小数
print("{0} is {0:>10.3f}".format(3.1415926))  # 保留3位小数,10字节右对齐输出
  • 2.3.2 格式化输出
格式符号功能
d十进制整数输出
b二进制输出
x十六进制输出,9-15以用小写字母a-f
o八进制输出
c字符,整数的话会转化为ASCII码
s字符串输出
e幂符号,用科学计数法打印数字
g一般格式,将数值以fixed-point number输出,数值很大的时候,用幂形式打印
n数字,当值为整数时和’d’相同,值为浮点数时和’g’相同,不同的是它会根据区域设置插入数字分隔符
%百分数,将数值乘以100然后以fixed-point number(‘f’)格式打印,会在后边加上%
print("d:{:d}".format(33))  # 十进制整数输出
print("b:{:b}".format(33))  # 二进制输出
print("x:{:x}".format(33))  # 十六进制输出,9-15以用小写字母a-f
print("o:{:o}".format(33))  # 八进制输出
print("c:{:c}".format(33))  # 字符,整数的话会转化为ASCII码
print("s:{:s}".format("hello"))  # 字符串输出
print("e:{:.13e}".format(33))  # 幂符号,用科学计数法打印数字
print("g:{:g}".format(33))  # 一般格式,将数值以fixed-point number输出,数值很大的时候,用幂形式打印
print("n:{:n}".format(33))  # 数字,当值为整数时和'd'相同,值为浮点数时和'g'相同,不同的是它会根据区域设置插入数字分隔符
print("%:{:.3%}".format(33))  # 百分数输出,保留三位小数
  • 2.3.3 汉字与字母输出对齐以及format参数嵌套

  在汉字与字母输出的过程中,汉字在utf8编码中被视为3个字节,在GBK编码中是2个字节,在uicode编码中是1个字节。

print(len("字节数"))                 # 默认编码格式下汉字长度
print(len("字节数".encode("utf8")))  # utf8下汉字长度
print(len("字节数".encode("GBK")))   # GBK下汉字长度

  在控制台进行汉字显示的时候,程序将其当作一个字节处理,但是显示的时候却是占用了两个字节的位置,这就导致了汉字与字母不能对齐的问题。如下例,打印表头及一些信息的时候,字母与汉字夹杂在一起,以同样的字节数打印,但是所占长度却不同。

Infos = [
        {"ID": "101", "name": "唐昊", "sex": "男", "age": "55", "phonenum": "11111111111"},  # 0
        {"ID": "102", "name": "Ayin", "sex": "女", "age": "50", "phonenum": "22222222222"},  # 1
        {"ID": "103", "name": "唐三", "sex": "男", "age": "20", "phonenum": "33333333333"},  # 2
        {"ID": "104", "name": "XiaoWu", "sex": "女", "age": "16", "phonenum": "55555555555"},  # 3
        ]
TableHeader = ["序号", "姓名", "性别", "年龄", "手机号"]

print("|{0:^{len0}s}|{1:^{len1}s}|{2:^{len2}s}|{3:^{len3}s}|{4:^{len4}s}|".format(
      TableHeader[0], TableHeader[1], TableHeader[2], TableHeader[3], TableHeader[4],
      len0=15, len1=15, len2=15, len3=15, len4=15))
for temp in Infos:
    print("|{0:^{len0}s}|{1:^{len1}s}|{2:^{len2}s}|{3:^{len3}s}|{4:^{len4}s}|".format(
            temp["ID"], temp["name"], temp["sex"], temp["age"], temp["phonenum"],
            len0=15, len1=15, len2=15, len3=15, len4=15))

  解决方法:len = 固定长度 - len(“中文内容”.encode(“GBK”)) + len(“中文内容”)

  比如“字节数”三个字,默认的字节长度为3,但是却要占用6个字节的位置,所以总的输出长度要减去这三个位置,才可以与其他的同长度的字符串对齐,所以就得到了上述的式子。
  所以修改程序如下

print("|{0:^{len0}s}|{1:^{len1}s}|{2:^{len2}s}|{3:^{len3}s}|{4:^{len4}s}|".format(
      TableHeader[0], TableHeader[1], TableHeader[2], TableHeader[3], TableHeader[4],
      len0=15 - len(TableHeader[0].encode("GBK")) + len(TableHeader[0]),
      len1=15 - len(TableHeader[1].encode("GBK")) + len(TableHeader[1]),
      len2=15 - len(TableHeader[2].encode("GBK")) + len(TableHeader[2]),
      len3=15 - len(TableHeader[3].encode("GBK")) + len(TableHeader[3]),
      len4=15 - len(TableHeader[4].encode("GBK")) + len(TableHeader[4])))
for temp in Infos:
    print("|{0:^{len0}s}|{1:^{len1}s}|{2:^{len2}s}|{3:^{len3}s}|{4:^{len4}s}|".format(
            temp["ID"], temp["name"], temp["sex"], temp["age"], temp["phonenum"],
            len0=15 - len(temp["ID"].encode("GBK")) + len(temp["ID"]),
            len1=15 - len(temp["name"].encode("GBK")) + len(temp["name"]),
            len2=15 - len(temp["sex"].encode("GBK")) + len(temp["sex"]),
            len3=15 - len(temp["age"].encode("GBK")) + len(temp["age"]),
            len4=15 - len(temp["phonenum"].encode("GBK")) + len(temp["phonenum"])))

2.4 不换行输出

  在python中的print函数在打印内容的时候会自动增加换行符号,但是print函数中有一个可选参数,就是end,使用end可以指定print结尾字符

  • 使用格式如下
print("hello world!", end="char")  # char为指定的结尾字符
  • 实例
print("hello world! 1")  # 不指定结尾字符,默认换行输出
print("hello world! 2")

print("hello world! 3", end="")  # 指定结尾字符为空格
print("hello world! 4")

print("hello world! 5", end="\t")  # 指定结尾字符为一个制表符
print("hello world! 6")

print("hello world! 7", end="|")  # 指定结尾字符为  |
print("hello world! 8")

三.转义字符

转义意义
\在行尾的续行符,即一行未完,转到下一行继续写
\\反斜杠(保留 \)
\’反斜杠(保留 ')
\"反斜杠(保留 ")
\b退格(Backspace)
\f换页
\n换行符
\r回车符
\t水平制表符
\xhh十六进制数,hh 代表字符,如 \x0a 代表换行
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值