零基础入门Python I/O:从Print函数开始

xiaoseyihe 2020-04-28

即将开播:4月29日,民生银行郭庆谈商业银行金融科技赋能的探索与实践

计算机程序用于执行任务,是满足人类需求的工具。有信息的输入,程序才能接收指令、理解需求;有信息的输出,运行结果才能被反馈给用户。在编程中,信息输入操作称为Input,输出操作称为Output,统称为Input/Output,简写为I/O。

零基础入门Python I/O:从Print函数开始

相比其他语言,Python中的I/O操作更加简单方便,通过简单的指令就可以实现基本的输入输出。此外,I/O并不仅仅指信息键入和打印信息,还包括文件的输入输出。

01 input与print

1. input

input函数在用于交互式的信息键入时,相当于一个容器,用户从键盘输入的信息先存放在容器中,再被变量引用。

input函数可以接纳多种数据类型,包括number、str等基础类型,及list、tuple、dict、set等复合类型。使用input函数时,可以在括号内添加str以提示输入。需要注意的是,Python 3.x中的input函数将所有接收的数据都默认为str,如下所示。

  • 输入不同数据类型
# 输入一个数字,由Python默认类型 
number1 = input('请输入一个数字:') 

输出结果:

请输入一个数字:1 
# 输入一个str,由Python默认类型 
str1 = input('请输入一个字符串:') 

输出结果:

请输入一个字符串:1 
# 输入一个数字,并将其转换为int类型 
number2 = int(input('请输入一个数字:')) 

输出结果:

请输入一个数字:123 
# 查看以上输入的输出结果类型 
print('number1、str1和number2的类型分别为:\n', 
    type(number1), type(str1), type(number2))     

输出结果:

number1、str1和number2的类型分别为: 
<class 'str'> <class 'str'> <class 'int'>     

从输出结果可知,在str1变量中,尽管输入的不是str,也被默认为str。要得到需要的数据类型,必须做类型转换。

2. print

给一个变量赋值后,如需查询变量的内容,只需要键入变量名并按回车键即可,称为表达式语句的输出。使用print函数是更受欢迎的输出方式,可以实现多样化的输出操作。

使用print函数进行输出操作时,可以在函数的括号中插入str以向屏幕上输出指定的文字,比如打印“hello,world!”的程序;要输出被赋值的变量,则在print函数的括号中插入变量名即可。

print函数也可以接收多个str,需要用逗号隔开,print函数会依次打印每个str,遇到逗号则输出一个空格,因此输出的str是拼起来的。print函数也可以自动计算结果,运行“print(number1+number2)”语句,解释器会自动计算出相加的结果后输出。print函数的应用代码如下所示。

  • print函数应用
# print函数接收多个str 
print('我', '爱', '中华')  

输出结果:

我 爱 中华 
# print函数在打印前计算结果 
print('100+200 =', 100 + 200) 

输出结果:

100+200 = 300 

格式化输出是计算机输出中的一个重要概念,主要针对str。其运行机制为:使用占位符在str中进行占位,再用数值或字符替换占位符,重组str后输出。

这种输出方法主要是为了方便修改语句,减少编写代码的工作量,并且包含自动取位、转换进制等功能。Python中的格式化输出方法有两种,即“%+格式符”的方法和format函数方法。

“%+格式符”的方法是一种较早的格式化输出方法,使用方式是在百分号(%)后加上相应的格式符以占位,再进行替换和输出。Python中的格式符如下所示。

  • Python格式符
  • str
  • %s:字符串(采用str函数的显示)
  • %r:字符串(采用repr函数的显示)
  • %c:单个字符
  • 整数
  • %b:二进制整数
  • %d:十进制整数
  • %i:十进制整数
  • %o:八进制整数
  • %x:十六进制整数
  • float
  • %e:指数(基底写为e)
  • %E:指数(基底写为E)
  • %f:浮点数
  • %F:浮点数

%g:指数(e)或浮点数(根据显示长度)

由此可知,Python中的格式符可分别用于str、整数和float输出。使用“%+格式符”的方法进行格式化输出,如下所示。

  • “%+格式符”格式化输出
# 用%s、%d分别格式化字符串'Zara'和整数20 
print("我的名字叫作%s,已经%d岁了!"%('Zara',20)) 

输出结果:

我的名字叫作Zara,已经20岁了! 
# 用%d格式化16,用%o将十进制整数16用八进制数表示 
print("%d 的八进制是 %o"%(16,16)) 

输出结果:

16 的八进制是 20 
# 用%.3f将整数转化为保留小数点后3位的float 
print("23 转化为保留3位小数的浮点数%.3f"%(23)) 

输出结果:

23转化为保留3位小数的浮点数23.000 

format函数是更为强大的格式化输出工具,format函数收集位置参数和关键字参数的任意集合,使用它们的值替换str中的占位符。该方法使用大括号({})作为特殊字符代替%,{}中可以不带参数、带数字编号或带关键字编号进行占位和替换,前两种属于位置替换方法,后一种属于关键字替换方法。

format函数也支持格式符,如下所示。

  • format函数格式符
  • 'c':字符。打印前将整数转换成对应的Unicode字符串
  • 'b':二进制。将数字以2为基数进行输出
  • 'o':八进制。将数字以8为基数进行输出
  • 'd':十进制。将数字以10为基数进行输出
  • 'x':十六进制。将数字以16为基数进行输出,9以上的位数用小写字母表示
  • 'e':幂符号。用科学计数法打印数字。用'e'表示幂
  • 'g':一般格式。将数值以fixed-point格式输出,数值特别大时用幂形式打印
  • 'n':数字。值为整数则等效于'd',为float则等效于'g'。
  • '%':百分数。数值乘以100后以fixed-point('f')格式打印,值后有一个百分号

使用format函数进行格式化输出的基本操作,如下所示。

  • format函数格式化输出
# format函数不带参数情况下的输出 
print("我的名字叫作{},已经{}岁了!".format('Zara', 18)) 

输出结果:

我的名字叫作Zara,已经20岁了! 
# format函数带数字编号并打乱顺序 
print("我的名字叫作{1},已经{0}岁了!".format(18, 'Zara')) 

输出结果:

我的名字叫作Zara,已经20岁了! 
# foemat函数带关键字参数 
print("我的名字叫作{name},已经{age}岁了!".format(age=18,name='Zara')) 

输出结果:

我的名字叫作Zara,已经20岁了! 
# format函数格式化数字为二进制数 
print("我的名字叫作{},已经{:b}岁了!".format('Zara', 18)) 

输出结果:

我的名字叫作Zara,已经10010岁了! 

02 文件I/O

1. open

内置函数open的作用是打开一个文件,创建一个file对象以进行调用。在打开文件的基础上,后续的文件读写操作才可以实现。open函数的基本语法格式如下:

open(filename, mode)

open函数常用的参数及其说明如下所示。

  • open函数常用的参数及其说明
  • filename:接收文件名,表示文件名称。无默认值
  • mode:接收模式名,表示文件打开模式。默认为只读

filename表示包含要访问的文件名称。mode决定打开文件的模式,这个参数是非强制的,默认的文件访问模式为只读(r),其可取值如下所示。

  • 文件访问模式及其说明
  • r:以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式
  • rb:以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式
  • r+:打开一个文件用于读写。文件指针将会放在文件的开头
  • rb+:以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头
  • w:打开一个文件只用于写入。如果该文件已存在则将其覆盖;如果该文件不存在,则创建新文件
  • wb:以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖;如果该文件不存在,则创建新文件
  • w+:打开一个文件用于读写。如果该文件已存在则将其覆盖;如果该文件不存在,则创建新文件
  • wb+:以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖;如果该文件不存在,则创建新文件
  • a:打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾,也就是说,新的内容将会被写到已有内容之后;如果该文件不存在,则创建新文件进行写入
  • ab:以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾,也就是说,新的内容将会被写到已有内容之后;如果该文件不存在,则创建新文件进行写入
  • a+:打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾,文件打开时会是追加模式;如果该文件不存在,则创建新文件用于读写
  • ab+:以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾;如果该文件不存在,则创建新文件用于读写

2. read

在Python中,读取文件的内容需要以只读的模式先打开一个文件,可以用open函数传入文件名和模式标识符,再用read函数读取文件中的内容。read函数可以从打开的文件中一次性读取全部内容,内容被读取到内存并用一个str对象表示。read函数的基本语法格式如下:

f = open(filename, mode) 
f.read(size) 

read函数常用的参数及其说明如下所示。

  • read函数常用的参数及其说明
  • size:接收number,表示读取的字符数。默认为文件中所有字符

size表示要从文件中读取的字节数,该方法从文件的开头开始读入,每调用一次就读取size个字节的内容。如果没有传入size,程序会尝试尽可能多地读取内容,一直到文件的末尾。

使用read函数读取test.txt文件,并打印,如下所示。

  • read函数读取test.txt文件
# 以只读模式打开test.txt文件 
data = open('../data/test.txt', 'r') 
# 读取文件中的内容,存到content变量中 
content = data.read() 
# 打印出content变量中包含的文本内容 
print('该文本中的内容是:', content) 

输出结果:

该文本中的内容是:Hello World! 

3. write

在Python中,写入文件和读出文件的操作方式是相似的:先调用open函数并传入标识符‘w’或‘wb’,再使用write函数进行写入。write函数的基本语法格式如下:

f = open(filename, mode) 
f.write(str) 

write函数常用的参数及其说明如下所示。

  • write函数常用的参数及其说明
  • str:接收任意str,表示写入的文本内容。默认为空

write函数可将任何str写入打开的文件。需要注意,Python中的str可以是二进制数据,而不限于文字。要写入str以外的内容,要先将需写入的内容转换成str。

使用write函数写入文件的操作如下所示。

  • write函数写入文件
# 打开一个文件 
web = open('../tmp/web.txt', 'w') 
# 转换内容,写入文件 
value = ('http://www.tipdm.org', 14) 
str_value = str(value) 
web.write(str_value) 
web.close() 
# 打开文本,读取出写入的内容 
web = open('../tmp/web.txt', 'r') 
content = web.read() 
print('该文本中的内容是:', content) 

输出结果:

该文本中的内容是: ('http://www.tipdm.org', 14) 

4. close

close函数可以刷新缓存里任何还没写入的信息并关闭文件,关闭之后的文件便不能再进行写入。使用完文件后应该关闭,关闭文件的本质是使文件指针与文件脱离,关闭后不再能通过该指针对原来与其联系的文件进行操作。

如果文件使用完后不关闭,文件对象会一直占用操作系统的资源,并且,操作系统同一时间能打开的文件数量是有限的。写入文件时,数据会占用操作系统的内存,待计算机空闲时再慢慢写入,不调用close函数的后果是数据可能只写一部分到磁盘中,其他的信息则丢失了。

close函数的基本语法格式如下:

fileObject.close() 

相关推荐