python中,open()的作用不包括读写对象

python中,open()的作用不包括读写对象,第1张

是的旁亩。

open是读写文件的第一步,通过open读写文件的方式和把大象装冰箱是一样的

f = open("test.txt",'w')#第一步,把冰箱门(文件)打开

f.write("this is content") #第二步,闹枝把大象(文件内容)装进去

f.close() #第三步,把冰箱门关上,否则大运弯森象可能会跑掉

我用这个方法读写文件时,却报错:IOError: [Errno 2] No such file or directory: '梁绝./output/http%3A//cup.baidu.com/spider'

我一开始很懵逼,明明这个方法,如果文件不存在的话,会自动创建文件的呀。。。而且,我的一级目录是存在的啊!

后来报着试一试的心态,我把output_filename改成了『http%3Acup.comspide』试了试,然后运凳拆行就通过橡粗姿了!

所以,最后定位到,肯定是文件名里的 / 未编码造成的!python会把它当成目录去寻找,那output下一层的目录那必然是不存在了。

于是,我就去看了看 output_filename 的生成,如下

这一看,我又开始懵逼了,我明明做编码处理了啊?为啥/没处理的

于是又开始百度,结果发现:urllib.quote(string,safe)这个函数是接收两个字段的,一个是需要编码的url地址,另一个safe是指定某个字符不被编码!然后,重点来了,safe默认赋值是『/』

最后,水落石出,更改如下:

就可以了!

输出就变成了:http%3A%2F%2Fcup.com%2Fspider

我们之前使用open方法读取文件

细心的朋友应该注意到,我们用open()打开文件以后,后面会跟着一个f.close()方法用来关闭文件,但是每次这么写,会很麻烦碰举慧。

所以,我们接下来介绍一下with open()的用法

调用read()方法,会一次性读取全部文件内容,当文件内容较小时比较试用,但是当文件内容过大,很容易导致运行内存100%,所以我们可以反复调用read(size)来设置每次读取的字节内容。

写入文件内容时:

我们写入文件内容时,系统并不会立刻就把所有数据写入到磁盘,它是先放到内存中缓存,等到空闲的时候再慢慢写入到磁盘。

当调用close()方法时,系统才能保证把剩余没有写入的数据全部写入到磁盘。假如我们忘记调用了close()方法,那很可能导致我们的数据遗失。

为了保证万无一失,最好是笑答使用with open()进行内容的读写。

try...finally

我在之前的文答凳章里面讲过try...finally,finally里面的内容是不管是否发生异常都会被执行。

所以,对于open()方法我们有另一种写法:

但是呢,这种方法相比with open()实在是太麻烦了,所以我们只是简单说一下,并不建议大家去使用这个方法。

多个文件的读写方式

with open()和open()读写文件的方法是通用的,没有区别


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/12214601.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-21
下一篇2023-05-21

发表评论

登录后才能评论

评论列表(0条)

    保存