Python3.5文件读与写操作经典实例详解

本文实例讲述了Python3.5文件读与写操作。分享给大家供大家参考,具体如下:

1、文件操作的基本流程:

(1)打开文件,得到文件句柄并赋值给一个变量

(2)通过句柄对文件进行操作

(3)关闭文件

2、基本操作举例:

现有一个命名为song.txt的文件,里面存放最喜爱的英文歌,内容如下:

take me to your heart
hiding from the rain and snow
藏身于雨雪之中
trying to forget but i won't let go
努力忘记,但我怎能就这样离去
looking at a crowded street
看着熙熙攘攘的街道
listening to my own heart beat
却只能听见自己的心跳
so many people all around the world
这么多的人在世界上
tell me where do i find someone like you girl
请告诉我在哪里可以找到像你一样的女孩
take me to your heart take me to your soul
将我留存心间与你的灵魂相伴
give me your hand before i'm old
给我你的手,在我老去之前
show me what love is haven't got a clue
问情为何物在我们彼此离开前
show me that wonders can be true
问奇迹上演
they say nothing lasts forever
他们说没有什么可以天长地久
we're only here today
我们也能此时相守
love is now or never
现在或者永不回头
bring me far away
请带我一起远走
take me to your heart take me to your soul
让我靠近你的心与你的灵魂相伴
give me your hand and hold me
给我你的手拥我入怀
show me what love is be my guiding star
问情为何物让星辰照亮我路
it's easy take me to your heart
其实爱我真的很简单以

在另一个命名为file_operation.py的文件中编写代码,使得以“utf-8”的编码格式将文件song.txt打开,并且读取该文件,将读取的内容返回到一个变量lyric中并打印出来。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# Author:ZhengzhengLiu

lyric = open("song",encoding="utf-8").read()
print(lyric)

运行结果将song.txt文件的内容打印出来:截图部分如下

3、文件基本操作

文件句柄:打开文件的返回值为文件句柄(文件的内存对象),对文件进行操作的是操作文件句柄。

(1)读文件内容

f = open("song",encoding="utf-8") #打开文件的返回值为文件句柄(文件的内存对象)
lyric = f.read() #读文件
print(lyric)  #打印读取内容

(2)写文件内容

f = open("song2",'w',encoding="utf-8") #w:只写模式。不存在的文件则创建;存在则覆盖原来文件的内容
f.write("Take me to your heart\n")
f.write("带我走进你的心")
f.close()

运行结果:

(3)在文件后边追加内容

f = open("song2",'a',encoding="utf-8") #a:追加模式。不存在的文件则创建;存在只追加内容
f.write("\nTake me to your soul\n")
f.write("带我走进你的心灵")
f.close()

运行结果:

(4)文件打开模式总结

.r,只读模式(默认)。
.w,只写模式。【不可读;不存在的文件则创建;存在则覆盖原来文件的内容】
.a,追加模式。【不可读;   不存在则创建;存在则只追加内容】

4、文件读操作

(1)文件读操作——读文件的第一行——调用:句柄.readline()

f = open("song",'r',encoding="utf-8")
first_line = f.readline() #读取第一行
print(first_line)

运行结果:

take me to your heart

(2)文件读操作——利用循环读取文件的前5行:

f = open("song",'r',encoding="utf-8")
for i in range(5):
 print(f.readline().strip())

运行结果:

take me to your heart
hiding from the rain and snow
藏身于雨雪之中
trying to forget but i won't let go
努力忘记,但我怎能就这样离去

句柄.readlines()将文件的内容以每行作为一个元素转换成一个列表

f = open("song",'r',encoding="utf-8")
print(f.readlines())

运行结果:

(3)文件读操作——利用句柄.readlines()循环读取文件的内容:

f = open("song",'r',encoding="utf-8")
for line in f.readlines():
 print(line.strip())

运行结果:

(4)文件读操作——利用句柄.readlines()循环读取文件的内容并处理特殊的行:

f = open("song",'r',encoding="utf-8")
for index,line in enumerate(f.readlines()):
 if index == 5:
  print("------------")
  continue
 print(line.strip())

运行结果:

(5)高效读取文件:当文件的内容很大时,采用readlines的方式需要先把文件转换成列表,耗费时间太长,内存里装不下太大的文件。
采用遍历并打印句柄的方式可以高效的实现文件的读取,这种方式采用一行行读取文件方式,内存里面每次只保存一行。

f = open("song",'r',encoding="utf-8")
for line in f:
 print(line.strip())

运行结果:

(6)高效读取文件——处理特殊行

count = 0
f = open("song",'r',encoding="utf-8")
for line in f:
 if count == 3:
  print("-------------")
  count+=1
  continue
 print(line.strip())
 count += 1

5、文件读完之后,文件句柄的指针移动到文件的末尾,想从头再读一遍,需要将指针移回到开始位置。

(1)查看文件句柄的指针指向的位置,调用.tell(),已读取的字符的个数即为计数的值(也是文件句柄指针指向的位置)。

f = open("song",'r',encoding="utf-8")
print(f.tell())
print(f.readline().strip()) #读取第一行
print(f.tell())

运行结果:

0
take me to your heart
23

f = open("song",'r',encoding="utf-8")
print(f.tell())
print(f.read(6)) #读取字符的个数
print(f.tell())

运行结果:

0
take m
6

(2)移动文件句柄指针,使其回到某个位置,调用.seek(指针的位置)

f = open("song",'r',encoding="utf-8")
print(f.tell())
print(f.readline().strip()) #读取第一行内容
print(f.tell())    #打印文件句柄指针的位置
f.seek(0)      #文件句柄指针回到起始位置
print(f.tell())
f.seek(30)     #文件句柄指针回到第30个字符的位置
print(f.readline().strip()) #从第30个字符开始读一行内容
print(f.tell())    #打印读取之后指针的位置

运行结果:

0
take me to your heart
23
0
from the rain and snow
54

6、打印文件的编码类型——调用:句柄.encoding()

f = open("song",'r',encoding="utf-8")
print(f.encoding)    #打印文件的编码类型

运行结果:

utf-8

7、打印文件的名字——调用:句柄.name

f = open("song",'r',encoding="utf-8")
print(f.name)    #打印文件名字

运行结果:

song

8、判断文件是否可读——调用:句柄.readable()

判断文件是否可写——调用:句柄.writable()

判断文件是否已经关闭——调用:句柄.closed()

判断文件句柄指针是否可移动——调用:句柄.seekable(),tty文件和终端设备文件的句柄指针不能移动

f = open("song",'r',encoding="utf-8")
print(f.readable()) #判断文件是否可读
print(f.seekable()) #判断文件句柄指针是否可移动
print(f.writable()) #判断文件是否可写

运行结果:

True
True
False

9、以写的模式打开一个文件,刚写完一行,突然断电,写的内容就没有写入硬盘当中,而是在内存的缓存中(硬盘的速度比内存慢)。
原本等到写入的内容在内存的缓存中满了,再一起写入硬盘中,调用句柄.flush()表示强制刷新到硬盘里面。

举例:动态打印字符:每隔0.1秒在屏幕输出打印一个#,一个打印20个

import sys,time

for i in range(20):
 sys.stdout.write("#") #向屏幕标准输出写入的字符
 sys.stdout.flush()  #强制刷新
 time.sleep(0.1)   #休眠时间

运行结果

####################

10、截断文件里面的内容——调用:句柄.truncate()   没有写参数,不做任何操作

调用:句柄.truncate(10)    参数10,代表从文件开头,截断10个字符

f = open("song",'a',encoding="utf-8")
f.truncate(20)    #从起始位置截断20个字符

11、"+" 表示可以同时读写某个文件

(1)r+   读写模式,注:写的内容从文件的最后面开始写入(写等同于追加),即:【可读;可写;可追加】

f = open("song",'r+',encoding="utf-8") #r+表示读写模式
for line in range(3):
 print(f.readline().strip())
f.write("-----------")

运行结果:

(2)w+   写读模式(应用不多):先创建一个文件然后再向里面写内容,注:写的内容从文件的最后面开始写入(写等同于追加)

f = open("song",'w+',encoding="utf-8")
f.write("-----------\n")
f.write("-----------\n")
f.write("-----------\n")

print(f.readline())
f.seek(14)
f.write("==========")
print(f.readline())
f.close()

运行结果:

(3).a+   追加读模式

12、"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)

应用:在网络传输只能用二进制模式进行传输;所有的二进制文件(如:视频)用二进制模式。

(1)二进制文件——读

f = open("song",'rb') #"b"表示处理二进制文件
for line in range(3):
 print(f.readline())

运行结果:

(2)二进制文件——写

f = open("song",'wb') #"b"表示处理二进制文件--写
f.write("Hello World\n".encode()) #需要将字符串编码成字节包(二进制格式)才能够写入
f.close()

运行结果:

13、"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)

(1)rU
(2)r+U

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python文件与目录操作技巧汇总》、《Python文本文件操作技巧汇总》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

(0)

相关推荐

  • Python3 中文文件读写方法

    字符串在Python内部的表示是Unicode编码,因此,在做编码转换时,通常需要以Unicode作为中间编码,即先将其他编码的字符串解码(decode)成Unicode,再从Unicode编码(encode)成另一种编码. 在新版本的python3中,取消了unicode类型,代替它的是使用unicode字符的字符串类型(str),字符串类型(str)成为基础类型如下所示,而编码后的变为了字节类型(bytes) 但是两个函数的使用方法不变: decode encode bytes ------

  • python 读写、创建 文件的方法(必看)

    python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 返回指定目录下的所有文件和目录名:os.listdir() 函数用来删除一个文件:os.remove() 删除多个目录:os.removedirs(r"c:\python") 检验给出的路径是否是一个文件:os.path.isfile() 检验给出的路径是否是一个目录:os.path.isdir() 判断是否是绝对路

  • Python open读写文件实现脚本

    1.open 使用open打开文件后一定要记得调用文件对象的close()方法.比如可以用try/finally语句来确保最后能关闭文件. file_object = open('thefile.txt') try: all_the_text = file_object.read( ) finally: file_object.close( ) 注:不能把open语句放在try块里,因为当打开文件出现异常时,文件对象file_object无法执行close()方法. 2.读文件 读文本文件 in

  • python3 读写文件换行符的方法

    最近在处理文本文件时,遇到编码格式和换行符的问题. 基本上都是GBK 和 UTF-8 编码的文本文件,但是python3 中默认的都是按照 utf-8 来打开.用不正确的编码参数打开,在读取内容时,会抛出异常. open(dirpath + "\\" + file, mode = "r+", encoding = "gbk", newline = "") 捕获抛出的异常,关闭文件.使用另外一种编码格式打开文件再重新读取. 读取

  • Python读写txt文本文件的操作方法全解析

    一.文件的打开和创建 >>> f = open('/tmp/test.txt') >>> f.read() 'hello python!\nhello world!\n' >>> f <open file '/tmp/test.txt', mode 'r' at 0x7fb2255efc00> 二.文件的读取 步骤:打开 -- 读取 -- 关闭 >>> f = open('/tmp/test.txt') >>&

  • Python3 读、写Excel文件的操作方法

    首先,简单介绍一下EXECL中工作簿和工作表的区别: 工作簿的英文是BOOK(WORKBOOK),工作表的英文是SHEET(WORKSHEET). •一个工作簿就是一个独立的文件 •一个工作簿里面可以有1个或者多个工作表 •工作簿是工作表的集合 1:使用python实现对Excel文件的读写,首先需要安装专用的模块(可以自己编写)xlrd,xlwt模块 2:读取excel数据(注意事项:sheet编号,行号,列号都是从索引0开始) import xlrd # 设置路径 path = 'E:/in

  • Python 文件读写操作实例详解

    一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法.1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()2.返回指定目录下的所有文件和目录名:os.listdir()3.函数用来删除一个文件:os.remove()4.删除多个目录:os.removedirs(r"c:\python")5.检验给出的路径是否是一个文件:os.path.isfile()6.检验给出的路径是否是一个目录:os.path.isdir()7.判断是

  • Python3之文件读写操作的实例讲解

    文件操作的步骤: 打开文件 -> 操作文件 -> 关闭文件 切记:最后要关闭文件(否则可能会有意想不到的结果) 打开文件 文件句柄 = open('文件路径', '模式') 指定文件编码 文件句柄= open('文件路径','模式',encoding='utf-8') 为了防止忘记关闭文件,可以使用上下文管理器来打开文件 with open('文件路径','模式') as 文件句柄: 打开文件的模式有: r,只读模式(默认). w,只写模式.[不可读:不存在则创建:存在则删除内容:] a,追加

  • python3.5基于TCP实现文件传输

    本文实例为大家分享了python3.5基于TCP实现文件传输的具体代码,供大家参考,具体内容如下 服务器代码 # _*_ coding:utf-8 _*_ from socket import * import _thread def tcplink(skt,addr): print(skt) print(addr,"已经连接上...") print('开始发送文件') with open('./ww.jpg', 'rb') as f: for data in f: print(dat

  • Python3.5 创建文件的简单实例

    实例如下所示: #coding=utf-8 ''' Created on 2012-5-29 @author: xiaochou ''' import os import time def nsfile(s): '''The number of new expected documents''' #判断文件夹是否存在,如果不存在则创建 b = os.path.exists("E:\\testFile\\") if b: print("File Exist!") el

  • python读写二进制文件的方法

    本文实例讲述了python读写二进制文件的方法.分享给大家供大家参考.具体如下: 初学python,现在要读一个二进制文件,查找doc只发现 file提供了一个read和write函数,而且读写的都是字符串,如果只是读写char等一个字节的还行,要想读写如int,double等多字节数 据就不方便了.在网上查到一篇贴子,使用struct模块里面的pack和unpack函数进行读写.下面就自己写代码验证一下. >>> from struct import * >>> fi

随机推荐