零基础入门学习Python(28)--文件
知识点
Python中使用open(...)
这个内置函数来打开文件,并返回文件对象
open()函数参数说明:
open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
file: 传入文件名,如果只有文件名(不带路径),Python会在当前文件夹里去查找这个文件并打开
mode: 文件打开模式,默认为r
(读取)
文件打开模式表
模式 | 说明 |
---|---|
r | 以只读模式打开(默认) |
w | 以写入方式打开文件,如果不存在则创建,存在则覆盖 |
x | 以写入模式创建一个文件,如果文件已经存在,使用此模式打开将引发异常FileExistsError |
a | 以写入模式打开,如果文件存在,则在末尾追加写入,不存在则创建 |
b | 以二进制模式打开文件 |
t | 以文本模式我打开(默认) |
+ | 可读写模式(可添加到其他模式中使用) |
U | 通用换行符模式(已弃用) |
文件对象方法
序号 | 方法 | 说明 |
---|---|---|
1 | file.close() | 关闭文件。关闭后文件不能再进行读写操作。 |
2 | file.flush() | 刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。 |
3 | file.fileno() | 返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。 |
4 | file.isatty() | 如果文件连接到一个终端设备返回 True,否则返回 False。 |
5 | file.next() | 返回文件下一行。 |
6 | file.read([size]) | 从文件读取指定的字节数,如果未给定或为负则读取所有。 |
7 | file.readline([size]) | 读取整行,包括 “\n” 字符。 |
8 | file.readlines([sizeint]) | 读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区。 |
9 | file.seek(offset[, whence]) | 设置文件当前位置 |
10 | file.tell() | 返回文件当前位置。 |
11 | file.truncate([size]) | 从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后 V 后面的所有字符被删除,其中 Widnows 系统下的换行代表2个字符大小。 |
12 | file.write(str) | 将字符串写入文件,没有返回值。 |
13 | file.writelines(sequence) | 向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。 |
各方法详细说明
close()
:
概述:
方法用于关闭一个已打开的文件。关闭后的文件不能再进行读写操作, 否则会触发 ValueError: I/O operation on closed file.
错误。 close() 方法允许调用多次。
当 file 对象,被引用到操作另外一个文件时,Python 会自动关闭之前的 file 对象。 使用 close() 方法关闭文件是一个好的习惯。
示例:
#!/usr/bin/python3
#打开文件
file1 = open('E:/test1.txt','wt')
print('文件名为:',file1.name)
#关闭文件
file1.close()
====输出结果====
文件名为: E:/test1.txt
file.flush()
概述
flush() 方法是用来刷新缓冲区的,即将缓冲区中的数据立刻写入文件,同时清空缓冲区,不需要是被动的等待输出缓冲区写入。
一般情况下,文件关闭后会自动刷新缓冲区,但有时你需要在关闭前刷新它,这时就可以使用 flush() 方法。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test1.txt','wt')
print('文件名为:',file1.name)
# 刷新缓冲区
file1.flush()
#关闭文件
file1.close()
====输出结果====
文件名为: E:/test1.txt
file.fileno()
概述
fileno() 方法返回一个整型的文件描述符(file descriptor FD 整型),可用于底层操作系统的 I/O 操作。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test1.avi','wt')
print('文件名为:',file1.name)
fid = file1.fileno()
print('文件描述符为: ', fid)
#关闭文件
file1.close()
====输出结果====
文件名为: E:/test1.avi
文件描述符为: 3
file.isatty()
概述
isatty() 方法检测文件是否连接到一个终端设备,如果连接到一个终端设备返回 True,否则返回 False。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test1.avi','wt')
print('文件名为:',file1.name)
ret = file1.isatty()
print('返回值: ', ret)
#关闭文件
file1.close()
====输出结果====
文件名为: E:/test1.avi
返回值: False
file.next()
概述
next(iterator[,default])
Python 3 中的 File 对象不支持 next() 方法。 Python 3 的内置函数 next()
通过迭代器调用 __next__()
方法返回下一项。 在循环中,next()方法会在每次循环中调用,该方法返回文件的下一行,如果到达结尾(EOF),则触发StopIteration
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r')
print('文件名为:',file1.name)
for each in range(1,7):
line = next(file1)
print("第 %d 行 - %s" % (each, line))
#关闭文件
file1.close()
===输出结果===
Traceback (most recent call last):
File "D:/untitled/Python_learn/File_Test.py", line 9, in <module>
line = next(file1)
StopIteration
文件名为: E:/test.txt
第 1 行 - 这是第一行
第 2 行 - 这是第二行
第 3 行 - 这是第三行
第 4 行 - 这是第四行
第 5 行 - 这是第五行
===输出结果===
文件名为: E:/test.txt
读取的字符串: 这是第一行
这是第二
file.read([size])
概述
read() 方法用于从文件读取指定的字节数,如果未给定或为负则读取所有。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r')
print('文件名为:',file1.name)
line = file1.read(10)
print("读取的字符串: %s" % (line))
#关闭文件
file1.close()
file.readline([size])
概述
readline() 方法用于从文件读取整行,包括 “\n” 字符。如果指定了一个非负数的参数,则返回指定大小的字节数,包括 “\n” 字符。
示例
text.txt文件内容:
1:https://blog.csdn.net/wanbin6470398/
2:https://blog.csdn.net/wanbin6470398/
3:https://blog.csdn.net/wanbin6470398/
4:https://blog.csdn.net/wanbin6470398/
5:https://blog.csdn.net/wanbin6470398/
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r')
print('文件名为:',file1.name)
line = file1.readline()
print("读取第一行: %s" % (line))
line = file1.readline()
print("读取第二行: %s" % (line))
line = file1.readline()
print("读取第三行: %s" % (line))
line = file1.readline(7)
print("读取的字符串: %s" % (line))
#关闭文件
file1.close()
===输出结果===
文件名为: E:/test.txt
读取第一行: 1:https://blog.csdn.net/wanbin6470398/
读取第二行: 2:https://blog.csdn.net/wanbin6470398/
读取第三行: 3:https://blog.csdn.net/wanbin6470398/
读取的字符串: 4:https
file.readlines([sizeint])
概述
readlines() 方法用于读取所有行(直到结束符 EOF)并返回列表,该列表可以由 Python 的 for… in … 结构进行处理。 如果碰到结束符 EOF 则返回空字符串。
如果碰到结束符 EOF 则返回空字符串。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r')
print('文件名为:',file1.name)
line = file1.readlines()
print("读取的数据: %s" % (line))
for each in line: #依次读取每行
each = each.strip() #去掉每行头尾空白
print("处理的数据为:%s" % each)
#关闭文件
file1.close()
===输出结果===
读取的数据: ['1:https://blog.csdn.net/wanbin6470398/\n', '2:https://blog.csdn.net/wanbin6470398/\n', '3:https://blog.csdn.net/wanbin6470398/\n', '4:https://blog.csdn.net/wanbin6470398/\n', '5:https://blog.csdn.net/wanbin6470398/\n']
处理的数据为:1:https://blog.csdn.net/wanbin6470398/
处理的数据为:2:https://blog.csdn.net/wanbin6470398/
处理的数据为:3:https://blog.csdn.net/wanbin6470398/
处理的数据为:4:https://blog.csdn.net/wanbin6470398/
处理的数据为:5:https://blog.csdn.net/wanbin6470398/
file.seek(offset[, whence])
概述
seek() 方法用于移动文件读取指针到指定位置。
参数
offset
– 开始的偏移量,也就是代表需要移动偏移的字节数
whence
:可选,默认值为 0。给offset参数一个定义,表示要从哪个位置开始偏移;0代表从文件开头开始算起,1代表从当前位置开始算起,2代表从文件末尾算起。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r')
print('文件名为:',file1.name)
line = file1.readline()
print("读取的数据: %s" % (line))
#重新设置文件读取指针到开头
file1.seek(0)
line = file1.readline()
print("读取的数据: %s" % (line))
#关闭文件
file1.close()
===输出结果===
文件名为: E:/test.txt
读取的数据: 1:https://blog.csdn.net/wanbin6470398/
读取的数据: 1:https://blog.csdn.net/wanbin6470398/
file.tell()
概述
tell() 方法返回文件的当前位置,即文件指针当前位置。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r')
print('文件名为:',file1.name)
line = file1.readline()
print("读取的数据: %s" % (line))
#获取当前位置
pos = file1.tell()
print("当前位置: %d" % pos)
#关闭文件
file1.close()
===输出结果===
文件名为: E:/test.txt
读取的数据: 1:https://blog.csdn.net/wanbin6470398/
当前位置: 40
file.truncate([size])
概述
truncate() 方法用于从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后 V 后面的所有字符被删除,其中 Widnows 系统下的换行代表2个字符大小。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r+')
print('文件名为:',file1.name)
print('读取行:%s' % file1.readline())
file1.truncate()
print('读取行:%s' % file1.readlines())
#关闭文件
file1.close()
===输出结果===
文件名为: E:/test.txt
读取行:1:https://blog.csdn.net/wanbin6470398/
读取行:['2:https://blog.csdn.net/wanbin6470398/\n', '3:https://blog.csdn.net/wanbin6470398/\n', '4:https://blog.csdn.net/wanbin6470398/\n', '5:https://blog.csdn.net/wanbin6470398/']
file.write(str)
概述
write() 方法用于向文件中写入指定字符串。
在文件关闭前或缓冲区刷新前,字符串内容存储在缓冲区中,这时你在文件中是看不到写入的内容的。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','r+',encoding='utf-8')
print('文件名为:',file1.name)
#在文件末尾写入一行
file1.seek(0,2)
file1.write('\n6:https://blog.csdn.net/wanbin6470398/')
print(file1)
#读取文件所有内容
file1.seek(0,0)
for index in range(1,7):
line = next(file1)
print("文件行号 %d - %s" % (index, line))
#关闭文件
file1.close()
===输出结果===
文件名为: E:/test.txt
<_io.TextIOWrapper name='E:/test.txt' mode='r+' encoding='utf-8'>
文件行号 1 - 1:https://blog.csdn.net/wanbin6470398/
文件行号 2 - 2:https://blog.csdn.net/wanbin6470398/
文件行号 3 - 3:https://blog.csdn.net/wanbin6470398/
文件行号 4 - 4:https://blog.csdn.net/wanbin6470398/
文件行号 5 - 5:https://blog.csdn.net/wanbin6470398/
文件行号 6 - 6:https://blog.csdn.net/wanbin6470398/
file.writelines(sequence)
概述
writelines() 方法用于向文件中写入一序列的字符串。
这一序列字符串可以是由迭代对象产生的,如一个字符串列表。
换行需要制定换行符 \n。
示例
#!/usr/bin/python3
# 打开文件
file1 = open('E:/test.txt','w+',encoding='utf-8')
print('文件名为:',file1.name)
seq = ['csdn1\n','csdn2\n','csdn3\n']
file1.writelines(seq)
#刷新缓冲区,把数据保存到磁盘
file1.flush()
#定位到文件开头位置
file1.seek(0)
print('文件内容:%s' % file1.read())
#关闭文件
file1.close()
===输出结果===
文件名为: E:/test.txt
文件内容:csdn1
csdn2
csdn3
课后习题
零基础入门学习Python(28)--文件的更多相关文章
- 【Python教程】《零基础入门学习Python》(小甲鱼)
[Python教程]<零基础入门学习Python>(小甲鱼) 讲解通俗易懂,诙谐. 哈哈哈. https://www.bilibili.com/video/av27789609
- 《零基础入门学习Python》【第一版】视频课后答案第001讲
测试题答案: 0. Python 是什么类型的语言? Python是脚本语言 脚本语言(Scripting language)是电脑编程语言,因此也能让开发者藉以编写出让电脑听命行事的程序.以简单的方 ...
- 零基础入门学习Python(1)--我和Python的第一次亲密接触
前言 最近在学习Python编程语言,于是乎就在网上找资源.其中小甲鱼<零基础入门学习Python>试听了几节课,感觉还挺不错,里面的视频都是免费下载,小甲鱼讲话也挺幽默风趣的,所以呢,就 ...
- 学习参考《零基础入门学习Python》电子书PDF+笔记+课后题及答案
国内编写的关于python入门的书,初学者可以看看. 参考: <零基础入门学习Python>电子书PDF+笔记+课后题及答案 Python3入门必备; 小甲鱼手把手教授Python; 包含 ...
- 学习《零基础入门学习Python》电子书PDF+笔记+课后题及答案
初学python入门建议学习<零基础入门学习Python>.适合新手入门,很简单很易懂.前一半将语法,后一半讲了实际的应用. Python3入门必备,小甲鱼手把手教授Python,包含电子 ...
- 零基础入门学习Python(36)--类和对象:给大家介绍对象
知识点 Python3 面向对象 Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对象是很容易的.本章节我们将详细介绍Python的面向对象编程. 如果你以前 ...
- 零基础入门学习Python(17)--函数:Python的乐高积木
前言 相信大家小时候都玩过神奇的乐高积木, 只要通过想象力和创造力我们可以拼凑很多神奇的东西,那么随着我们学习的深入,我们编写的Python代码也将日益增加,并且也越来越复杂, 所以呢,我们需要找寻一 ...
- 零基础入门学习Python(29)--文件:一个任务
知识点 一个任务:将文件(record.txt)中的数据进行分割并按照以下规律保存起来: #record.txt文件内容: 小客服:小甲鱼,今天有客户问你有没有女朋友? 小甲鱼:咦?? 小客服:我跟她 ...
- 零基础入门学习Python(35)--图形用户界面入门:EasyGui
知识点 EasyGui学习文档[超详细中文版] 1. 建议不要在IDLE上运行EasyGui EasyGui是运行在TKinter上并拥有自身的事件循环,而IDLE也是Tkinter写的一个应用程序并 ...
随机推荐
- Linux Gcc编译错误(转载)
转自:http://www.linuxidc.com/Linux/2012-01/52153.htm Linux系统下的c编程与Windows有所不同,如果你在用gcc编译代码的时候提示‘for’ l ...
- 版本控制系统Git
常用的版本控制系统有VSS.SVN.CVS等等,Git是最近几年使用得比较多的分布式版本控制系统,存在即合理,Git的出现总有它出现的理由,以前的版本控制系统肯定有一些不足的地方,所以才出现了Git. ...
- bzoj 4236: JOIOJI【前缀和+map】
设sj,so,si分别是J O I的个数前缀和,然后要求求最长(l,r)满足sj[r]-sj[l-1]==so[r]-so[l-1]==si[r]-si[l-1],化简一下就是满足so[r]-so[l ...
- NOIp 2014 寻找道路【图的遍历/最短路】By cellur925
题目传送门 比较裸的图论,结果自己还是没做出来,我真菜. 我们根据题意,只要把不能通向终点的点求出,然后再分别以这些点为起点,求出它们能到达的点,这些点也不能在路径上. 之后跑一个最短路即可. 注意以 ...
- 自己动手利用CentOS6.5 搭建php环境安装discuz论坛
1.安装搭建论坛必要的软件 apache php mysql CentOS系统我们可以直接使用 yum install 的方式进行软件安装,腾讯云有提供软件安装源,是同步CentOS官方的安装源,包涵 ...
- bzoj1233 [Usaco2009Open]干草堆tower 【单调队列dp】
传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1233 单调队列优化的第一题,搞了好久啊,跟一开始入手斜率优化时感觉差不多... 这一题想通了 ...
- SIFT特征点检测与匹配
SIFT的步骤如下: (1) 尺度空间极值检测(Scale-space Extrema Detection) 也就是在多尺度高斯差分(Difference of Gauss)空间中检测极值点(3x3x ...
- 题解报告:hdu 1166 敌兵布阵(线段树or树状数组)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 Problem Description C国的死对头A国这段时间正在进行军事演习,所以C国间谍头 ...
- c#如何使用replace函数将"\"替换成"\\"
当我使用 String str="c:\aa.xls"; str=str.Replace("\","\\");时,括号为红色错误的,那么如何 ...
- .NET通过字典给类赋值
/// <summary> /// /// </summary> /// <typeparam name="T"></typeparam& ...