从文件中读取数据

首先准备一个文本文件,文件中存储着普通文本数据。读取文件需要调用open()和read()函数。

读取整个文件

代码示例:

withopen('pi_digits.txt')asfile_object:contents=file_object.read()print(contents)

open()函数

在读取文件之前,必须先要打开文件,这样才能访问它。打开文件需要调用open()函数,它接受一个参数:要打开的文件路径名称(可以是相对路径,也可以是绝对路径,相对路径时,Python将会以当前执行的文件所在的目录作为相对位置去查找指定的文件)。

注意:在Linux和OS X中,使用斜杠(/)分割文件路径;而在Windows系统中,使用反斜杠(\)分割文件路径。

函数open()返回一个表示文件的对象。例如此处的open('pi_digits.txt') 返回一个表示文件pi_digits.txt的对象,Python将这个对象存储在我们将在后面使用的变量file_object中。

with关键字

关键字with在不再需要访问文件后将其关闭。它可以解决显式调用close()函数可能出现的一些问题,如果显式的调用close()函数,一旦程序出现异常,导致close()语句还未执行,文件将不会关闭,而且如果过早的调用close(),将会出现文件读取错误,因此使用with关键字可以很好的避免这类问题,Python让你只管打开文件,并在需要时使用它,Python自会在合适的时候自动将其关闭。

另外还需要注意一点,使用关键字with时,open()返回的文件对象只在with代码块内可用。

read()函数

如果不给read()函数传递参数,将会读取全部内容。

注意:read()读取到文件末尾时会返回空白符(文本的末尾有一个看不见的换行符),为了去除多余的空白,应该结合使用rstrip()函数:

#去除字符串末尾的多余空白print(contents.rstrip())

逐行读取

#逐行读取withopen('pi_digits.txt')asfile_object2:forline infile_object2:print(line.rstrip())

可以直接使用for循环遍历文件对象,去读取每一行。

创建一个包含文件各行内容的列表

使用关键字with时,open()返回的文件对象只在with代码块内可用,可以先将读取的内容放入一个列表中,然后在with代码块的外面去访问文件的内容。

#创建包含文件各行内容的列表withopen('pi_digits.txt')asfile_object3:#从文件中读取每一行,并将其存储在一个列表中lines=file_object3.readlines()#在with代码块的外面读取该列表forline inlines:print(line.rstrip())

将数据写入文件

将数据写入到文件中,需要调用open()和write()函数。

写入空文件

filename='test.txt'#写入空文件withopen(filename,'w')asfile_obj:file_obj.write('hello python!')

写入文件时,也需要使用open()函数先打开文件,不同的是打开文件的模式不同。open()函数的第一个参数用来指定文件名,第二个参数指定打开的模式,相关模式如下:

写入模式(w):如果文件不存在,将会创建一个空文件。如果文件已经存在,将会在返回该文件对象前清空该文件。即永远以空文件的形式返回文件对象,不管该文件是否有数据。

读取模式(r):如果open()函数省略了模式实参,将默认以该模式打开文件,即文件只能读取不能写入。

附加模式(a):不清空原文件,而是将新写入的内容附加到原文件的末尾。如果文件不存在,将会创建一个空文件,并附加内容。

读取和写入模式(r+)

使用open()写入文件时,如果文件不存在,将会自动创建它。

写入多行

#写入多行withopen(filename,'w')asfile_obj2:file_obj2.write('java \n')file_obj2.write('python \n')

write()函数不会在你写入的文本末尾添加换行符,因此写入多行时,需要手动的在字符串的末尾添加换行符(\n)。

附加到文件

#附加到文件withopen(filename,'a')asfile_obj3:file_obj3.write('one \n')file_obj3.write('two \n')

以附加模式打开文件时,python不会在返回文件对象前清空文件,而是将要写入到文件的内容追加到原文件的末尾。如果指定的文件不存在,将创建一个空文件,并附加内容。

异常

Python在程序执行期间发生错误时,都会创建一个异常对象,如果不做处理,将会显示一个Traceback,其中包含有关异常的报告。为了处理异常,在Python中的异常使用try-except代码块处理。

使用try-except代码块

当你认为可能发生错误时,可以编写try-except代码块来处理可能引发的异常。代码块格式如下:

try:可能会发生异常的代码片段except异常对象:异常处理的代码片段

例如,捕捉被除数为0引发的ZeroDivisionError异常对象:

try:print(5/0)exceptZeroDivisionError:print('被除数不能为0')

try-except-else代码块

else代码块不是必须的,它只有在需要依赖于try代码块成功执行时才需要。它在try-except中的结构位置如下:

try:片段1except异常对象:片段2else:片段3

try-except-else代码块的工作原理:python尝试执行try代码块中的片段1代码,片段1的代码应该是只有可能引发异常的代码,不会引发异常的代码不要放在try代码块中(片段1)。如果片段1的代码发生了异常,就执行片段2的代码进行异常处理,否则,如果片段1的代码没有发生异常,就执行片段3的代码,片段3的代码应该是仅在片段1的代码成功执行时才需要运行的代码。

whileTrue:first_num=input("第一个数:")iffirst_num=='q':breaksecond_num=input('第二个数:')try:result=int(first_num)/int(second_num)exceptZeroDivision
Error:print('被除数不能为0')else:print('值为:'+str(result))

使用pass关键字在抛出异常时不做任何处理

如果在捕获到异常时,并不想写任何处理操作,可以直接在片段2的代码中,使用pass关键字。

try:片段1except异常对象:pass

pass语句还充当了占位符,它提醒你在程序的某些对方什么都没有做,并且以后也许要在这里做些什么。

处理FileNotFoundError异常

使用文件读写操作时,如果文本名错误或文件不存在,就会抛出异常。此时,可以通过捕获FileNotFoundError异常对象进行处理。

filename='alice.txt'try:withopen(filename)asf_obj:contents=f_obj.read()exceptFileNotFoundError:print('文件找不到!')

附加:存储JSON格式数据到文件中

需要导入json模块来存储数据,然后调用json.dump()和json.load()分别存储和读取JSON数据。

使用json.dump()来存储数据

#导入json模块importjson
numbers=[2,3,5,7,11,13]filename='numbers.json'withopen(filename,'w')asf_obj:#存储数据json.dump(numbers,f_obj)

使用json.load()来读取数

importjson
filename='numbers.json'withopen(filename)asf_obj:#读取数据numbers=json.load(f_obj)print(numbers)