Python中文件的读取和写入操作

作者:爱上羊羊的小灰灰 时间:2023-01-08 22:05:52 

从文件中读取数据

读取整个文件

这里假设在当前目录下有一个文件名为'pi_digits.txt'的文本文件,里面的数据如下:

3.1415926535
8979323846
2643383279


with open('pi_digits.txt') as f: # 默认模式为‘r',只读模式
 contents = f.read() # 读取文件全部内容
 print contents # 输出时在最后会多出一行(read()函数到达文件末会返回一个空字符,显示出空字符就是一个空行)
 print '------------'
 print contents.rstrip() # rstrip()函数用于删除字符串末的空白

3.1415926535
8979323846
2643383279
------------
3.1415926535
8979323846
2643383279

逐行读取

可以通过循环来实现逐行读取数据:


with open('pi_digits.txt') as f:
 for line1 in f:
   print line1 # 每行末尾会有一个换行符
 print '------------'
 for line2 in f:
   print line2.rstrip() # 此时文件已经读完,line2指向文本末尾,因此不会有输出

3.1415926535

8979323846

2643383279

------------

读取文件时相当于有一个指针在记录读取的位置,数据读到哪,这个指针就指到哪边,继续读取数据时会从该位置继续读取,因此上面代码中第二个循环中输出为空。将上述代码稍加修改如下:


with open('pi_digits.txt') as f:
 for line1 in f:
   print line1
 print '------------'
with open('pi_digits.txt') as f: # 需要重新打开文本进行读取
 for line2 in f:
   print line2.rstrip() # 删除字符串末尾的空白

3.1415926535

8979323846

2643383279

------------
3.1415926535
8979323846
2643383279

上述代码相当于第一次读取完后关闭该文件又重新打开进行读取。逐行读取数据也可以用readline()函数,如下:


with open('pi_digits.txt') as f:
 # readline()每一次读取一行数据,并指向该行末尾
 line1 = f.readline() # 读取第一行数据(此时已经指向第一行末尾)
 line2 = f.readline() # 从上一次读取末尾开始读取(第二行)
 print line1.rstrip()
 print line2.rstrip()

3.1415926535
8979323846

有时候我们想要一次性读取全部数据并且按分开存储以便于后续的操作,当然用上面的循环可以实现,但python提供了更简单的方法readlines():


with open('pi_digits.txt') as f:
 lines = f.readlines() # 读取文本中所有内容,并保存在一个列表中,列表中每一个元素对应一行数据
print lines # 每一行数据都包含了换行符
print '------------'
for line in lines:
 print line.rstrip()  
print '------------'
pi_str = '' # 初始化为空字符
for line in lines:
 pi_str += line.rstrip() #字符串连接
print pi_str

['3.1415926535\n', '8979323846\n', '2643383279\n']
------------
3.1415926535
8979323846
2643383279
------------
3.141592653589793238462643383279

写数据到文件

写数据有几种不同的模式,最常用的是w', ‘a', 分别表示擦除原有数据再写入和将数据写到原数据之后:


filename = 'write_data.txt'
with open(filename,'w') as f: # 如果filename不存在会自动创建, 'w'表示写数据,写之前会清空文件中的原有数据!
 f.write("I am Meringue.\n")
 f.write("I am now studying in NJTECH.\n")

此时会在当前路径下创建一个'write_data.txt'的文本文件,并向文件中写入数据如下:

I am Meringue.
I am now studying in NJTECH.

下面继续在该文件中加入新数据:


with open(filename,'a') as f: # 'a'表示append,即在原来文件内容后继续写数据(不清楚原有数据)
 f.write("I major in Machine learning and Computer vision.\n")

此时的文件内容为:

I am Meringue.
I am now studying in NJTECH.
I major in Machine learning and Computer vision.

总结

以上所述是小编给大家介绍的Python中文件的读取和写入操作网站的支持!

来源:https://blog.csdn.net/sinat_34474705/article/details/77389258

标签:python,文件,读取,写入
0
投稿

猜你喜欢

  • MySql之授权用户权限如何设置

    2024-01-21 21:56:13
  • Python使用正则表达式过滤或替换HTML标签的方法详解

    2023-02-08 10:49:52
  • 如何用GAN训练自己的数据生成新的图片

    2023-04-13 16:45:07
  • oracle数据库在客户端建立dblink语法

    2023-07-14 19:51:23
  • Python MySQLdb 使用utf-8 编码插入中文数据问题

    2023-07-31 11:04:13
  • Python3 安装PyQt5及exe打包图文教程

    2021-09-24 12:43:56
  • Python基础知识方法重写+文件处理+异常处理

    2022-09-20 06:43:43
  • python读写ini文件示例(python读写文件)

    2023-06-21 03:10:14
  • C#连接Oracle数据库的方法

    2024-01-16 20:17:12
  • Pandas数据查询的集中实现方法

    2021-08-17 10:32:27
  • 基于Python把网站域名解析成ip地址

    2021-08-23 05:31:06
  • 基于matplotlib中ion()和ioff()的使用详解

    2021-11-23 17:54:27
  • python笔记(2)

    2021-10-16 21:50:00
  • MSSQL差异备份取系统权限的相关软件下载

    2024-01-21 16:08:46
  • django多对多表的创建,级联删除及手动创建第三张表

    2022-08-13 02:10:48
  • python实现简单通讯录管理系统

    2021-05-02 10:41:23
  • JS代码格式化和语法着色

    2013-07-14 19:47:45
  • 富文本编辑器的基本原理与实践

    2008-06-13 13:28:00
  • 如何利用Tensorflow2进行猫狗分类识别

    2021-06-29 18:58:12
  • 分享python 写 csv 文件的两种方法

    2023-04-07 07:03:47
  • asp之家 网络编程 m.aspxhome.com