1. 简单的读取文件内容(codecs的使用)
当前目录下有个1.txt的文档
打开文件的步骤:
import codecs
(1)open文件
f = codecs.open('1.txt')
(2)文件操作(读或写)
print (f.read())
(3)关闭文件
f.close()
结果如下:
这个方法等于把整个文件拿出来,当成一个字符串来使用,后期用正则匹配的时候,非常方便、适用。
【codecs 这个模块,是open打开文件的时候,引入这个模块,用途:解决文件乱码的。推荐以后在读写的时候使用这个模块】
如果设:
text = f.read()
查看text的类型:
print (type(text))
查看到类型是"str"(字符串)
类型是字符串,我们就可以使用字符串的方法:
result = text.replace('1', 'A')
print (result)
2. 写入一个新的文件
import codecs
f = codecs.open('2.txt', 'w')
f.write('hello world!\n')
f.write('hello {0}!\n'.format('LLN'))
f.write('you cool!\n')
f.write('I like it!\n')
f.close()
注释:
# open(filename, mode)
# mode有几个参数:
r 读取
w 写入
b 二进制
a 追加
3. 文件操作常用用法
readlins() 方法:
此方法,读取文件,把每一行都变成单独的字符串,并放入到一个列表中去,第一行为列表的第一个元素,以此类推。
举例:
import codecs
f = codecs.open('1.txt', 'rb')
t_list = f.readlines()
print (t_list[0]
print (f.readlines())
f.close()
返回结果:
1111111111 第一行
[]
注释:
为什么 print (f.readlines()) 会返回空列表?
因为之前readlines()已经将文件读到末尾了,下次再用readlines()方法读的时候,会从文章最末尾开始读取,所以结果为[]。
readline() 方法:
此方法,读取文件,每一个readline()只读取一行,光标会停留在下一行的开头;
在执行下一个readline()的时候,会从光标处读取当前这一行。
import codecs
f = codecs.open('1.txt', 'rb')
print (f.readline())
print (f.readline())
print (f.readline())
print (f.readline())
print (f.readline())
f.close()
返回结果:
1111111111
aaaaaaaaaa
2222222222
bbbbbbbbbb
3333333333
next()方法:
对比:
readline() 读取文件一行内容,返回一个字符串
next() 读取文件下一行内容返回一个字符串
write()方法和writelines()方法:
write() 必须传入一个(整个)字符串
writelines() 必须传入一个序列
举例1:
import codecs
f = codecs.open('2.txt', 'wb')
f.write('hello lili\n cccccccc\n aaaaaaaaaa\n') ## 一个整的字符串
f.close()
可以看到多出来一个文件:
文件内容:
举例2:
import codecs
f = codecs.open('2.txt', 'wb')
f.writelines(['aaaaa\n','bbbbbbbb\n','cccccccc']) ##传入一个列表(序列)
f.close()
可以看到多出来一个文件的内容:
tell()方法:
提示当前光标落在哪个字符位置上
举例:
import codecs
f = codecs.open('3.txt', 'wb')
f.writelines(['aaaaa\n','bbbbbbbb\n','cccccccc'])
print f.tell()
f.close()
返回:
23
seek()方法:
指定光标的位置,seek(0)是移动到文章开头
举例:
import codecs
f = codecs.open('3.txt', 'wb')
f.writelines(['aaaaaaaaaaaaaaa\n','bbbbbbbbbbbbb\n','cccccccc\n'])
print f.tell()
f.seek(0)
f.write('sssssssssssssssss') ##重新写入
f.close()
返回结果:
sssssssssssssssssbbbbbbbbbbbb
cccccccc
从结果看出,将光标移动到开头后,并在开头写入字符串,并替换掉原有字符串对应的位置的字符,文件总长度不变。
4.with的特殊用法
举例:
import codecs
with codecs.open('1.txt', 'rb') as f:
print (f.read())
这种方法不需要写close(),在执行完成后,会自动关闭文件。
拓展:
打印文件指定行的内容:
方法一:
import codecs
with codecs.open('1.txt', 'rb') as f:
for line, value in enumerate(f):
if line == 4-1: #打印第四行的内容,下标为3
print (value)
方法二:(python有个自带的方法)
import linecache
count = linecache.getline(filename,linenum)
举例:
import linecache
count = linecache.getline('1.txt',4) ##下标为3
print count