1 从文件中读取数据

1.1 读取整个文件

创建名为test的txt文本文件,添加内容如下所示:

1234567890
2345678901
3456789012

实现代码:

 with open('test.txt') as file_object:
contents = file_object.read()
print(contents)

运行结果:

工作原理:

#1 open()方法用于打开一个文件:输入参数---文件名称(默认在当前目录中查找);返回一个表示文件的对象。

#1 关键字with:打开文件后,Python会在合适的时候将打开的文件自动关闭,避免造成不必要的麻烦。

#2 read()方法:读取文件的全部内容,并将其作为一个长字符串存储在变量contents中。

#3 打印存储在变量contents中的内容。

打印结果与原始文件相比,末尾处出现一个空行。这是因为read()方法到达文件末尾时会返回一个空字符串,而将这个空字符串显示出来时就是一个空行。

要删除多余出来的空行,可使用rstrip()函数(删除字符串末尾空白):

 with open('test.txt') as file_object:
contents = file_object.read()
print(contents.rstrip())

运行结果:

1.2 文件路径

默认情况下,read()方法只会在当前目录中进行查找文件,不会在其子文件夹中查找。

如果要打开一个不在当前目录中的文件,则需要提供该文件路径,以便Python在特定路径去查找该文件。

有两种提供文件路径的方法:相对文件路径和绝对文件路径。

例如,假设Python源文件位于名为work的文件夹中,txt文件位于work的子文件夹files中。

这种情况下,我们可以提供相对文件路径来打开该文件夹中的文件:

 with open('files\test.txt') as file_object:

此外,你也可以提供绝对文件路径来打开该文件夹中的文件:

 with open('...\work\files\test.txt') as file_object:

当绝对文件路径比较长时,可以先将其存储在一个变量中,如file_path:

 file_path = '...\work\files\test.txt'
with open(file_path) as file_object: 

1.3 逐行读取

实现代码:

 filename = 'test.txt'

 with open(filename) as file_object:
for line in file_object:
print(line)

运行结果:

运行后发现每行文本之后都有空行,原因是:1. 文件中每行末尾都有一个看不见的换行符;2. print语句也会加上一个换行符。

因此每行文本后面都会跟随两个换行符:一个来自文件;一个来自print语句。

同样地,要消除这些空白行,可以在print语句中加入rstrip():

 filename = 'test.txt'

 with open(filename) as file_object:
for line in file_object:
print(line.rstrip())

运行结果:

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

使用关键字with时,open()返回的文件对象只在with代码块内可用。

若要在with代码块之外访问文件内容,可在with代码块内将文件的各行内容存储在一个列表中,并在with代码块外使用该列表。

实现代码:

 filename = 'test.txt'

 with open(filename) as file_object:
lines = file_object.readlines() for line in lines:
print(line.rstrip())

运行结果:

工作原理:

#4 readlines()从文件中读取每一行,并将其存储在一个列表中,再传递给变量lines。

当文件内容被读取到内存后,你就可以以任何方式使用这些数据了。

2 写入数据到文件中

2.1 写入空文件

要将文本写入文件,需要在调用open()时提供另一个实参,以告知Python你要写入打开的文件。

实现代码:

 filename = 'test.txt'

 with open(filename, 'w') as file_object:
file_object.write("Hello World!")

工作原理:

#3 open()提供了两个参数:1. 打开文件名称;2. 'w'告知Python以写入模式打开文件。

#4 write()方法将一个字符串写入文件。

[注1]:'r'表示只读模式,'a'表示附加模式,'r+'表示读取和写入模式。若省略此实参,Python将以默认的只读模式打开文件。

[注2]:若要写入的文件不存在,open()函数将自动创建它。

[注3]:千万小心,若指定文件已存在,Python将在返回文件对象之前清空该文件。

2.2 写入多行

函数write()不会在你写入的文本末尾添加换行符,因此,如果你写入多行时没有指定换行符,文件看起来可能不会那么的井然有序。

要让每个字符串单独占据一行,可以在write()语句中包含换行符。

实现代码:

 filename = 'test.txt'

 with open(filename, 'w') as file_object:
file_object.write("Hello World!\n")
file_object.write("my great friends.\n")

当然,你还可以使用空格、制表符和空行等来设置写入文本的格式。

2.3 附加到文件

如果你要给文件添加内容,而不是覆盖原有的内容,可以附加模式打开文件。

当你以附加模式打开文件时,Python不会在返回文件对象前清空文件,而你写入到文件的行都将添加到文件末尾。

如果指定的文件不存在,Python将为你创建一个空文件。

实现代码:

 filename = 'test.txt'

 with open(filename, 'a') as file_object:
file_object.write("Python\n")
file_object.write("Java\n")

运行结果:

Python读取和写入文件的更多相关文章

  1. python读取与写入csv,txt格式文件

    python读取与写入csv,txt格式文件 在数据分析中经常需要从csv格式的文件中存取数据以及将数据写书到csv文件中.将csv文件中的数据直接读取为dict类型和DataFrame是非常方便也很 ...

  2. 读取和写入 文件 (NSFIleManger 与 NSFileHandle)

    读取和写入 文件 //传递文件路径方法 -(id)initPath:(NSString *)srcPath targetPath:(NSString *)targetPath { self = [su ...

  3. python读取Excel表格文件

    python读取Excel表格文件,例如获取这个文件的数据 python读取Excel表格文件,需要如下步骤: 1.安装Excel读取数据的库-----xlrd 直接pip install xlrd安 ...

  4. python读取和写入csv文件

    读取csv文件: def readCsv(): rows=[] with file(r'E:\py\py01\Data\system.csv','rb') as f: reads=csv.reader ...

  5. python读取并写入mat文件

    用matlab生成一个示例mat文件: clear;clc matrix1 = magic(5); matrix2 = magic(6); save matData.mat 用python3读取并写入 ...

  6. python将对象写入文件,以及从文件中读取对象

    原文地址: http://www.voidcn.com/article/p-fqtqpwxp-wo.html 写入文件代码: >>> import sys, shelve >& ...

  7. python读取/创建XML文件

    Python中定义了很多处理XML的函数,如xml.dom,它会在处理文件之前,将根据xml文件构建的树状数据存在内存.还有xml.sax,它实现了SAX API,这个模块牺牲了便捷性,换取了速度和减 ...

  8. python读取、写入txt文本内容

    转载:https://blog.csdn.net/qq_37828488/article/details/100024924 python常用的读取文件函数有三种read().readline().r ...

  9. 【转】MFC中用CFile读取和写入文件2

    原文网址:http://blog.sina.com.cn/s/blog_623a7fa40100hh1u.html CFile提供了一些常用的操作函数,如表1-2所示. 表1-2  CFile操作函数 ...

随机推荐

  1. HttpClient的userAgent和refer问题

    HttpClient本质是模拟浏览器去请求网址,获取请求response. 为了更真实的模拟浏览器,不被限制,需要设置一些请求header. 如果是爬虫的话,老虑的会更多些,爬取网站在HttpClie ...

  2. python学习笔记(18)字典和json 的区别 和转换

    字典和json 的区别 和转换 前言:字典和json非常像.接下来比较一下两者的异同 先看一下字典的写法: a = {'a':'1', 'b':'2', 'c':'3' } 再看一下json的写法: ...

  3. socket握手SYN和ACK理解

    ACK 英文缩写: ACK (ACKnowledge Character) 中文译名: 确认字符 分类: 传输与接入 解释: 在数据通信传输中,接收站发给发送站的一种传输控制字符.它表示确认发来的数据 ...

  4. Office 365管理员添加自定义域名

    添加自定义域,以便Office 365允许更短.更熟悉的的电子邮件或用户ID用于服务 一.Office 365小型企业版添加自定义域名 1.使用Office 365管理员账户登陆到由世纪互联运营的Of ...

  5. Linux下安装mysql(yun方式)

    1.进入下载好的mysql版本 cd /usr/local/mysql 2.解压安装包 tar -xzvf mysql-5.7.11.tar.gz 3.改名 直接改或者 mv  文件名 要改的文件名m ...

  6. Users组权限Win7虚拟机继承Administrator的个性化设置

    在administrator账号下进行的模板设置,配置文件保存在“C:\Documents and Settings\Administrator”文件夹下的profile里面,但是创建的用户虚拟机获取 ...

  7. 密码子演化假说|凝固事件假说|立体化学假说|共进化假说|代谢途径相关性假说|四重兼并|假四重兼并|最小损伤原则|AU-rich|GC-rich|逐步进化假说|分子机制进化假说

    生命组学 将密码子表重排后发现,嘌呤嘧啶含量不同,密码子的氨基酸种类由第一二位决定,同时第三位变化大却没有蛋白质层面上实质性的改变,这说明第三位氨基酸是用于维持氨基酸组成不发生变化同时保证蛋白质稳定性 ...

  8. 洛谷-P3809-后缀排序(后缀数组)

    看了求后缀数组的倍增法之后很快就理解了,但是自己写的倍增法用map排序还是超时了.然后看了两天别人写的模板,题目是通过了,但感觉代码还是半懂半背的.以后多熟悉熟悉吧: 后缀数组 #include &q ...

  9. EMP平台简介(转载)

    1.什么是EMP EMP平台是一个基于J2EE体系的.WEB应用的.基础框架平台: 表现逻辑框架(MVCFrameWork)与业务逻辑框架(EMPBizLogic)分离: 组件化.配置化设计技术: 可 ...

  10. 如何卸载烦人的2007组件,windows提供的解决方案

    如何卸载烦人的2007组件:很恶心人各种软件已经手动删除卸载都无法用,不是cd/dvd找不到就是什么msi文件找不到:对于这种恶心的问题,windows提供了如下解决方案:我使用fixit轻松卸载,很 ...