
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()读写文件的方法是通用的,没有区别
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)