文件操作:
1.f=open(”caidan”,”w”,encoding=”utf8”) 直接打开一个文件,如果文件不存在则创建文件
f.close()
2.with open (”caidan”,”w”,encoding=”utf8”)as f
关于open 模式:
w 以写方式打开,
a 以追加模式打开
r+ 以读写模式打开(写的时候光标在最后,读的时候光标在最前边)
w+ 以写读模式打开 (先清空后将内容写入 )
a+ 以追加读模式打开 (光标在最后,要写入先定光标 )
文件操作方法
f.read() #()为读取的长度,以byte为单位f.readline()
#读一行,打印第一行
f.readlines()
#把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。f.write()
#写到文件中,写入的为字符串类型write()并不会在str后加上一个换行符
f.writelines()
#把seq的内容全部写到文件中(多行一次性写入)。这个函数也只是忠实地写入,不会在每行后面加上任何东西
f.close()
#关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生错误
f.flush()
#把缓冲区的内容写入硬盘(可做进度条)
fp.fileno()
#返回一个长整型的”文件标签“
fp.isatty()
#文件是否是一个终端设备文件(unix系统中的)
fp.tell()
#返回文件操作标记的当前位置,以文件的开头为原点
fp.next()
#返回下一行,并将文件操作标记位移到下一行。把一个file用于for … in file这样的语句时,就是调用next()函数来实现遍历的。
fp.seek()
#文件操作标记。调整光标位置,一般是相对于文件的开头来计算的,一般为正数。但如果提供了参数就不一定了,参数可以为0表示从头开始计算,1表示以当前位置为原点计算。2表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。
fp.truncate()
#截断(不可在“r”模式下执行,在“w”下先清空再写入后截断,在“a”下直接截断)
f=open("abc","r",encoding="utf8")
print(f.tell())
print(f.readline(2))
print(f.tell())
print(f.seek(3))
print(f.readline())
f.close()
在文件里存的全是字符串
字符串转为字典为a=eval()
字典转为字符串为a=str{}
counter = 0
f=open("abc","r",encoding="utf8")
f2=open("abc2","w",encoding="utf8")
for i in f.readlines():
counter += 1
if counter ==5:
i = ''.join((i.strip(),'safag\n'))
print(i.strip())
f2.write(i)
f2.close()
f.close()