100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > python的输出函数_Python输出函数print()总结(python print())

python的输出函数_Python输出函数print()总结(python print())

时间:2023-03-26 21:32:05

相关推荐

python的输出函数_Python输出函数print()总结(python print())

Python 思想:

“一切都是对象!”

python版本:python3.5.1 ; IDE:pycharm.2

一、print()函数概述

print() 方法用于打印输出,是python中最常见的一个函数。

该函数的语法如下:

print(*objects, sep=' ', end='\n', file=sys.stdout)

参数的具体含义如下:

objects --表示输出的对象。输出多个对象时,需要用 , (逗号)分隔。

sep -- 用来间隔多个对象,表示各个输出字符串之间的间隔字符,可自定义,默认是空格。

end -- 用来设定以什么结尾。默认值是换行符 \n,我们可以换成其他字符。

file -- 要写入的文件对象。

print(1) #数值类型可以直接输出

'''

运行结果如下

1

'''

print("Hello World") #字符串类型可以直接输出

'''

运行结果如下:

Hello World

'''

a=1

b="Hello World"

print(a, b) #可以一次输出多个对象,对象之间用逗号分隔

'''

运行结果如下:

1 Hello World

'''

#如果直接输出字符串,而不是用对象表示的话,可以不使用逗号

print("Duan""Yixuan")

print("Duan","Yixuan")

'''

运行结果如下:

DuanYixuan

Duan Yixuan

可知,不添加逗号分隔符,字符串之间没有间隔

'''

print("www", "snh48", "com", sep=".") # 设置间隔符

'''

运行结果如下:

'''

可以定义一个输出中的换行行为

a, b = [], []

for _ in (range(3)):

a.append(random.randint(20, 30))

b.append(random.randint(20, 30))

print(a, b, sep='\n')

'''

运行结果如下:

[30, 30, 29]

[22, 28, 25]

'''

二、变量的输出

无论什么类型的数据,包括但不局限于:数值型,布尔型,列表变量,字典变量...都可以直接输出。

#例如:

num = 19

print(num) #19 输出数值型变量

str = 'Duan Yixuan'

print(str) #Duan Yixuan 输出字符串变量

list = [1,2,'a']

print(list) #[1, 2, 'a'] 输出列表变量

tuple = (1,2,'a')

print(tuple) #(1, 2, 'a') 输出元组变量

dict = {'a':1, 'b':2}

print(dict) #{'a': 1, 'b': 2} 输出字典变量

三、数据的格式化输出

在C语言中,我们可以使用printf("%-.4f",a)之类的形式,实现数据的的格式化输出。

在python中,我们同样可以实现数据的格式化输出。我们可以先看一个简单的例子:

s='Duan Yixuan'

x=len(s)

print('Teh length of %s is %d' %(s,x))

'''

'Teh length of %s is %d' 这部分叫做:格式控制符

(s,x) 这部分叫做:转换说明符

% 字符,表示标记转换说明符的开始

输出如下:

Teh length of Duan Yixuan is 11

'''

和C语言的区别在于,Python中格式控制符和转换说明符用%分隔,C语言中用逗号。

接下来我们仔细探讨一下格式化输出

3.1 %字符

(1).%字符:标记转换说明符的开始。

%字符的用法可参考上例,不再赘述。

3.2 最小字段宽度和精度

最小字段宽度:转换后的字符串至少应该具有该值指定的宽度。如果是*(星号),则宽度会从值元组中读出。

点(.)后跟精度值:如果需要输出实数,精度值表示出现在小数点后的位数。如果需要输出字符串,那么该数字就表示最大字段宽度。如果是*,那么精度将从元组中读出。

可参考C语言的实现方式。

注:字段宽度中,小数点也占一位。

PI = 3.141592653

print('%10.3f'%PI) #字段宽10,精度3

# 3.142

#精度为3,所以只显示142,指定宽度为10,所以在左边需要补充5个空格,以达到10位的宽度

PI=3.1415926

print("PI=%.*f"%(3,PI))

#用*从后面的元组中读取字段宽度或精度,可以读取出来精度是3位

#PI=3.142

#没有指定宽度,所以不需要缩进

print("PI=%*.3f"%(10,PI)) #精度为3,总长为10.

# PI= 3.142

#* 所处的位置不同,读取的内容也不同

3.3 转换标志

转换标志:-表示左对齐;+表示在数值前要加上正负号;" "(空白字符)表示正数之前保留空格();0表示转换值若位数不够则用0填充。

具体的我们可以看一下例子:

PI=3.1415926

print('%-10.3f' %PI) #左对齐,还是10个字符,但空格显示在右边。

#3.142

PI=3.1415926

print('%+f' % PI) #显示正负号 #+3.141593

# 类型f的默认精度为6位小数。

PI=3.1415926

print('%010.3f'%PI) #字段宽度为10,精度为3,不足处用0填充空白

#000003.142 0表示转换值若位数不够则用0填充

3.4 格式字符归纳

格式字符 说明 格式字符 说明

%s 字符串采用str()的显示 %x 十六进制整数

%r 字符串(repr())的显示 %e 指数(基底写e)

%c 单个字符 %E 指数(基底写E)

%b 二进制整数 %f,%F 浮点数

%d 十进制整数 %g 指数(e)或浮点数(根据显示长度)

%i 十进制整数 %G 指数(E)或浮点数(根据显示长度)

%o 八进制整数 %% 字符%

四、换行与防止换行

在python中,输出函数总是默认换行,比如说:

for x in range(0,5):

print(x)

'''

0

1

2

3

4

'''

而显然,这种输出太占“空间”,我们可以进行如下改造:

参考文本第一部分对end参数的描述:end -- 用来设定以什么结尾。默认值是换行符 \n,我们可以换成其他字符。

for x in range(0, 5):

print(x, end=' ')

#0 1 2 3 4

for x in range(0, 5):

print(x, end=',')

#0,1,2,3,4,

但如果,我们同时运行上面两段代码,结果会如下所示,可知:我们需要在两次输出间,实现换行。

for x in range(0, 5):

print(x, end=' ')

for x in range(0, 5):

print(x, end=',')

#0 1 2 3 4 0,1,2,3,4,

我们比较以下几种方式

方式一:

for x in range(0, 5):

print(x, end=' ')

print('\n')

for x in range(0, 5):

print(x, end=',')

'''

0 1 2 3 4

0,1,2,3,4,

'''

方式二:

for x in range(0, 5):

print(x, end=' ')

print() #本身自带换行,完美输出

for x in range(0, 5):

print(x, end=',')

'''

0 1 2 3 4

0,1,2,3,4,

'''

五、高级用法

《PythonLinux系统管理和自动化运维》第48页,代码如下:

...

meta = [fileinput.filename(), fileinput.fileno(), fileinput.filelineno(),

fileinput.isfirstline(), fileinput.isstdin()]

print(*meta, end="")

...

因为之前根本就没有听说过这种用法,所以就自己写了个脚本测试一下,经过几次测试之后,终于弄懂了这个的用法。

首先,print() 是输出数据的,这点我们一定要牢记,所以不论我们的这个 meta 里面有什么,那么最后出来的一定需要是字符串或者其他类型的数据,我们才能得到最后的输出。

在这个前提下,我们对这句代码

print(*meta)

有三种假设的情况。

第一种:把列表内容当作命令去执行,然后在命令中完成我们的输出。

第二种:如果列表内容是命令,执行列表内容,否则输出内容。

第三种:依次执行列表中是命令的选项,然后拿到返回值作为内容代替命令,最后统一输出所有的内容。

很明显,第一种第二种显然不可能,因为如果我们单独执行fileinput.filename()等,肯定会返回一个字符串,那么就和我们的假设相悖,所以我们要向第三种可能靠近。

所以编写了个脚本去测试猜想:

def hello():

print("你好啊")

def other():

print("this is inner of other")

return "other"

meta = [print("hello world"), hello(), "测试文本", other()]

print(*meta, end="")

print()

执行的结果是下面这个:

可以证明,我们的猜想是正确的,结果显示,先输出了 hello world 你好啊 dis is ineer of other ,说明是先执行了这三个命令,然后拿到返回值,输出,并且由于print函数和hello函数没有返回值,所以是None,空,也证明我们的猜想的正确性。

资料来源:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。