c
0.下边只有一种方式不能打开文件,请问是哪一种,为什么?
f = open('E:/test.txt','w') #A
f = open('E:\test.txt','w') #B
f = open('E://test.txt','w') #C
f = open('E:\\test.txt','w') #D
B,没有对反斜杠进行转义
1.打开一个文件我们使用open()函数,通过设置文件的打开模式,决定打开的文件具有哪些性质,请问默认的打开模式是什么呢?
'r’只读模式
2.请问>>>open(‘E:\Test.bin’,‘xb’)是以什么样的模式打开文件的?
以写入及二进制打开文件
3.尽管python有所谓的“垃圾回收机制”,但对于打开了的文件,在不需要用到的时候我们仍然需要使用f.close()将文件对象“关闭”,这是为什么呢?
4.如何将一个文件对象(f)中的数据存放进列表中?
list(f)
5.如何迭代打印出文件对象(f)中的每一行数据?
for each_line in f:
print(each_line)
6.文件对象的内置方法f.read([size=-1])作用是读取文件对象内容,size参数是可选的,那如果设置了size=10,例如f.read(10),将返回什么内容呢?
读取文件指针当前位置往后读10个字符
7.如何获得文件对象(f)当前文件指针的位置?
f.tell()
8.还是视频中的那个演示文件(record.txt),请问为何f.seek(45,0)不会出错,但f.seek(46)就出错了呢?
f.seek(46)
46f.readline()
Traceback (most recent call last):
File “<pyshell#18>”,line 1, in
f.readline()
UnicodeDecodeError:‘gbk’ codec can’t decode byte 0xe3 in position 4: illegal multibyte sequence
因为使用f.seek()定位的文件指针是按字节为单位进行计算的,演示文件(record.txt)是以GBK进行编码的,按照规则,一个汉字需要占用两个字节,f.seek(45)的位置位于字符“小”的开始位置,因此可以正常打印,而f.seek(46)的位置刚好位于字符“小”的中间位置,因此按照GBk编码的形式无法将其解码!
动动手:
0.尝试将文件(OpenMe.mp3)打印到屏幕上
直接使用打开文本文件的形式打开即可
f = open('OpenMe.mp3')
for each_line in f:
pring(each_line,end='')
f.close()
1.编写代码,将上题中的文件(OpenMe.mp3)保存为新文件(OpenMe.txt)
f1 = open('OpenMe.mp3')
f2 = open('OpenMe.txt','x')
f2.write(f1.read())
f2.close()
f1.close()
标答: