首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python学习 :文件操作

Python学习 :文件操作

作者头像
py3study
发布2020-01-19 14:37:09
发布2020-01-19 14:37:09
45900
举报
文章被收录于专栏:python3python3
运行总次数:0

文件基本操作流程:

一、 创建文件对象 

二、 调用文件方法进行操作

三、 关闭文件(注意:只有在关闭文件后,才会写入数据)

代码语言:javascript
代码运行次数:0
运行
复制
fh = open('李白诗句','w',encoding='utf-8')
fh.write('''弃我去者,昨日之日不可留;
乱我心者,今日之日多烦忧。
长风万里送秋雁,对此可以酣高楼。
蓬莱文章建安骨,中间小谢又清发。
''')
fh.close()

open()函数的不同模式:

读操作

read()  #默认显示所有文本

代码语言:javascript
代码运行次数:0
运行
复制
fh = open('李白诗句',encoding='utf-8')
print(fh.read())
>>>  弃我去者,昨日之日不可留;
   乱我心者,今日之日多烦忧。
   长风万里送秋雁,对此可以酣高楼。
   蓬莱文章建安骨,中间小谢又清发。

read(4)  #显示4个字符

代码语言:javascript
代码运行次数:0
运行
复制
fh = open('李白诗句',encoding='utf-8')
print(fh.read(4))  #显示4个字符
>>> 弃我去者

readline()  #只读取一行,每次调用输出一行

代码语言:javascript
代码运行次数:0
运行
复制
fh = open('李白诗句',encoding='utf-8')
print(fh.readline())
['弃我去者,昨日之日不可留;]

readlines()   #将文件中各行读出来,放到一个列表中返回。列表中每个元素都是文件的一行,并且都是字符串

代码语言:javascript
代码运行次数:0
运行
复制
fh = open('李白诗句',encoding='utf-8')
print(fh.readlines())
['弃我去者,昨日之日不可留;\n', '乱我心者,今日之日多烦忧。\n', '长风万里送秋雁,对此可以酣高楼。\n', '
蓬莱文章建安骨,中间小谢又清发。\n', '俱怀逸兴壮思飞,欲上青天览明月。\n', '抽刀断水水更流,举杯消愁愁更愁。\n', '人生在世不称意,明朝散发弄扁舟。']

写操作

write()  #把文件写入缓冲区,当文件关闭时才会写入内存

对于大数据文件:

如果文件很大,乃至于内存空间不足,就不能继续使用 read()或者readlines()操作

因为文件是可迭代的对象,直接用 for 来迭代即可

代码语言:javascript
代码运行次数:0
运行
复制
fh = open('李白诗句',encoding='utf-8')
number = 0
for i in fh:  # 这是for内部将f对象做成一个迭代器,用一行去一行。
    number += 1
    print(i.strip())
     弃我去者,昨日之日不可留  
   乱我心者,今日之日多烦忧。
   长风万里送秋雁,对此可以酣高楼。
   蓬莱文章建安骨,中间小谢又清发。        

其他操作方法:

1、tell() 查看光标当前的位置

2、seek()

   seek(offset ,[whence]) 方法改变当前文件的位置

   offset变量表示要移动的字节数。whence变量表示要从哪个位置开始偏移

   注意:默认以文件的开头未参照物进行移动,即 whence = 0,这时候 offset 必须是大于等于0 的整数

      当 whence = 1时,表示从当前位置开始计算偏移量。如果 offset 是负数,表示从当前位置向前移动;如果 offset 是正数,表示从当前位置向后移动

      当 whence = 2时,表示相对文件末尾移动

3、使用 with 语句操作(在 with 语句中就不用close()了)

代码语言:javascript
代码运行次数:0
运行
复制
with open('李白诗句','r',encoding='utf-8') as fh:
    print(fh.readline())
>>>    弃我去者,昨日之日不可留;

4、flush()  用来刷新缓冲区,将缓冲区中的数据立刻写入文件,同时清空缓冲区

5、truncate() 用于截断文件,如果指定了可选参数 size,则表示保留前size 个字节,删除 size 后面的所有字符。 如果没有指定 size,则从当前位置起截断。

        不能在r模式下

        在w模式下:先清空,再写,再截断

        在a模式下:直接将指定位置后的内容截断

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/03/14 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文件基本操作流程:
  • open()函数的不同模式:
  • 读操作
  • 写操作
  • 对于大数据文件:
  • 其他操作方法:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档