本文将主要介绍在Python中,如何读取文本文件,以及如何将内容写入到文件中。为了读取文件,我们预先设计一个名为sample1.txt的文件,放在和源代码相同的目录中。而且为了取得较好的演示效果,我们特意把文件的内容设计为"第XX行"。文件的位置如下所示:
文件的内容如下所示:
在Python中,文件的打开是使用open函数,函数有2个参数,第1个参数是文件名称,第2个参数是读写的模式。'r'是只读模式,'w'是写入模式,如果文件已经存在了,就会清空里面的所有内容,'a'是追加模式,写入的内容会自动追加到文件最后,'r+'是指同时读写模式。'b'是指二进制模式。
在Python中文件的基本操作流程是:open()函数read()/write()函数close()函数。以下是一个文件处理的基本程序源代码
在这个程序中,我们使用open('sample1.txt', 'r')打开一个叫sample1.txt的文件,文件的模式是r,说明这是一个只读模式。read(size)函数是读取文件的内容。如果参数size省略的话,将读取整个文件。在本例中,由于文件很小,所以我们不使用size参数,一次性将内容读取到变量content中。内容读取完之后,我们可以使用print来看一下文件内容是否读取正常。
通过执行结果,我们可以看到content的内容就是文本文件的内容,三行被一次性读到变量中。最后我们使用close函数,关闭文件。
在平时工作中,我们读取文本文本一般都会按行来读取,而使用read函数按字节来读取就会有一些困难,因此我们一般会使用readline()。下面的例子我们演示了readline的使用。
readline函数每次只读取一行文本。当读到文件结尾的时候,函数将返回一个空字符串。因此,我们使用while content!=""进行判断是否已经读到文件结尾。如果文件没有到结尾,我们就继续readline。这里需要说明一下的是,如果读取的是一个空行,那么content的值将会是"",这也是Python特意设计的,以便和空字符串""区分开,才好识别是读到了空行,还是文件结尾。即空字符串""代表文件结尾,""代表空行。
其实在Python中,我们还有一个更加高效,并且好用的方法来循环读取文本文件的内容,就是使用for和in,这样我们就不再需要写过多的代码进行判断,程序的源代码如下,实现的效果其实是一样的。
在上面程序的基础上,我们再深入一些,实际工作中,我们在读取文件的时候,程序都会伴随着各种复杂的操作,可能会遇到很多意外情况。为了更好的确保程序能正确的关闭文件。通常我们会使用 with 关键字。程序的源代码如下所示:
想像一样,在实际工作中,我们可能有很长很长的操作。现在我们缩短操作的过程,使用上面的程序做演示。虽然我们没有直接调用close,但是Python可以确保恰当的关闭文件,效果有点儿类似try…finally,但是整体上要更简洁一些。
至此,关于文本文件读取的内容,就先告一段落,下面我们看一下写入文本文件的实例。
写入文件使用的是write函数。write只接受字符串形式的参数。因此,我们可以看到在源代码的最后一行,我们要想写入time或者数值型变量时,我们是使用了format函数。其中time类型,我们使用strftime进行了转换,转成了字符串类型
文件写入后的效果如下,第1行是直接将字符串写入文件,第2行中我们通过format格式化之后,整理形成了一段带有时间和数值的字符串,然后再写入文件中。
以上就是关于读取和写入文本文件的基本操作。
我使用的环境:Windows 7 + Python 2.7.17 + PyCharm Community Edition 2016.1.5
如果大家认为我的文章还可以,真心希望能帮我点一个"关注",粉丝的数量真的对我很重要,也算是对我努力结果的一个支持,谢谢大家了。