博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
6.2Python文件的操作(二)
阅读量:6891 次
发布时间:2019-06-27

本文共 2278 字,大约阅读时间需要 7 分钟。

目录

目录

前言

该篇是相继上一篇6.1Python文件操作(一)之后的进阶文章。

(一)文件的定位

(1)说明

f.tell() 返回当前文件指针所在的位置。

f.seek(偏移量, 参考点) 根据参考点来偏移 偏移量个单位。

参考的:可以是0, 1, 2

0: 开头处, 参考点是正的

1:中间位置,参考点可正可负

2:结尾处:参考点是负的

注:文本文件的参考点只能是0,二进制文件三者皆可。

(2)源代码

# 打开f = open("a.txt", "rb")# 指针的位置r1 = f.tell()print("前指针的位置:", r1)# 偏移指针,参考点: 文本文件只能是0,二进制文件可以是:1, 2f.seek(-2, 2)r1 = f.tell()print("后指针的位置:", r1)# 读content = f.read()print("内容是:", content)r1 = f.tell()print("读完指针的位置:", r1)# 关闭f.close()

(3)输出效果

a.txt的内容是:12345678

01.png

(二)文件的读操作

==1.read()方法==

(1)说明

f.readable()用于判断该文件是否可读

f.read(字节数) ,默认情况下字节 数是文件的长度。

(2)源代码

# 打开文件f = open("b.txt", "r")# 判断是否可读print(f.readable())if f.readable():    # 操作, n 要读的文件长度    content = f.read(5)    print(content)# 关闭文件f.close()

(3)输出效果

b.txt 的内容是:123456789

02.png

==2.readline()方法==

(1)说明

readline()方法是逐行的读写,每一次只读一行。

(2)源代码

# 打开文件f = open("c.txt", "r")# 操作, n 要读的文件长度content = f.readline()print(content, end='')content = f.readline()print(content, end='')content = f.readline()print(content, end='')# 关闭文件f.close()

(3)输出效果

c.txt的内容是:

12
34abcdefgh
56
78

03.png

==3.readlines()方法==

(1)说明

readlines()方法是以行为单位来读,返回每一行为一个元素的列表 。

(2)源代码

# 打开文件f = open("c.txt", "r")# 操作, n 要读的文件长度content = f.readlines()print(content)# 关闭文件f.close()

(3)输出效果

c.txt的内容是:

12
34abcdefgh
56
78

04.png

==4.文件的遍历读法==

(1)说明

打开的文件 f 本身就是一个迭代器,可以用for循环来遍历输出。与resdlines()类似,用行为单位来处理。

(2)源代码

# 打开文件f = open("c.txt", "r")# f是一个迭代器与readlines()效果一样for i in f:    print(i, end='')# 关闭文件f.close()

(3)输出效果

c.txt的内容是:

12
34abcdefgh
56
78

05.png

(三)文件的写操作

==1.write()方法==

(1)说明

f.writable()用于判断该文件是否可选。

f.write()方法返回的是本次写入的字节数。

encoding="utf-8" 参数是指明写入的编码格式。

(2)源代码

# 打开文件f = open("d.txt", "a", encoding="utf-8")# 判断是否可写if f.writable():    # 写入文件    result = f.write("123456")    print("写入的字节数是:", result)# 关闭文件f.close()

(3)输出效果

06.png

==2.writelines()方法==

(1)说明

f. writelines()方法是以列表的每一个元素,写入到文件的每一行,列表的元素必须是字符串类型。

注:每一个列表的元素后面需要添加 "\n" 才换行,默认是不换行。

(2)源代码

# 打开文件f = open("e.txt", "w", encoding="utf-8")# 写入文件f_list = ["14\n", "28\n", "abc\n", "哈哈"]f.writelines(f_list)# 关闭文件f.close()

(3)输出效果

07.png

(四)文件的关闭

(1)说明

f.close()是关闭文件,内部是把缓存区的数据,写到内存,才实现真正的保存操作。

同时也释放系统资源。

f.flush() 是立即把缓存区的数据写入到内存里区,实现及时的保存。

(2)源代码

# 打开文件f = open("f.txt", "w")# 操作文件f.write("123456")# 及时保存数据f.flush()# 关闭文件f.close()

(3)输出效果

08.png

作者:Mark

日期:2019/02/08 周五

转载于:https://www.cnblogs.com/zyg123/p/10356057.html

你可能感兴趣的文章
第 2 章 容器架构 - 008 - Docker 组件如何协作?
查看>>
JSON与XML的区别比较
查看>>
android AsyncTask使用限制
查看>>
1-22
查看>>
excel-填充
查看>>
alpine 容器优化
查看>>
python IDLE操作
查看>>
浙大pat甲级题目---1028. List Sorting (25)
查看>>
HttpSession详解
查看>>
Springboot使用junit
查看>>
PHP学习之环境搭建
查看>>
NVelocity用法
查看>>
『追捕盗贼 Tarjan算法』
查看>>
QTP的那些事---有关web的自动化测试框架saffron的使用
查看>>
Struts2标签的<s:set>标签的用法
查看>>
win7 下强制删除文件
查看>>
firewalld
查看>>
Majority Element问题---Moore's voting算法
查看>>
第十二周学习总结
查看>>
面试题目
查看>>