1 打开文件
‘r’ 以只读的方式打开文件(默认)
'w' 以写入的方式打开文件,会覆盖已存在的文件
'x' 如果文件已存在,使用此模式打开将引发异常
'a' 以写入模式打开,如果文件存在,则在末尾追加写入
'b' 以二进制模式打开文件
't' 以文本模式打开(默认)
'+' 可读写模式(可添加到其他模式中使用)
'U' 通用换行符支持
2 文件对象方法
f.close() 关闭文件
f.read(size=-1) 从文件读取size个字符,当未给定size或给定为负值时,读取 剩余的所有字符,然后作为字符串返回
f.readline() 以写入模式打开,如果文件存在,则在末尾追加写入
f.write() 将字符串str写入文件
f.writelines(seq) 向文件写入字符串序列seq,seq应该是一个返回字符串的可迭代对象
f.seek(offset,from) 在文件中移动文件指针,从from(0代表文件起始位置,1代表当前位置,2代表文件末尾)偏移offset个字节
f.tell() 返回当前在文件中的位置
>>> f = open ('D:\\PythonWenjian\\xiaojiayu\\record.txt')
>>> f
<_io.TextIOWrapper name='D:\\PythonWenjian\\xiaojiayu\\record.txt' mode='r' encoding='cp936'>
>>> f.read()
'小客服:小甲鱼,今天有客户问你有没有女朋友?\n小甲鱼:咦??\n小客服:我跟她说你有女朋友了!\n小甲鱼:。。。。。。\n小客服:她让你分手后考虑下她!然后我说:"您要买个优盘,我就帮您留意下~"\n小甲鱼:然后呢?\n小客服:她买了两个,说发一个货就好~\n小甲鱼:呃。。。。。。你真牛!\n小客服:那是,谁让我是鱼C最可爱小客服嘛~\n小甲鱼:下次有人想调戏你我不阻止~\n小客服:滚!!!\n================================================================================\n小客服:小甲鱼,有个好评很好笑哈。\n小甲鱼:哦?\n小客服:"有了小甲鱼,以后妈妈再也不用担心我的学习了~"\n小甲鱼:哈哈哈,我看到丫,我还发微博了呢~\n小客服:嗯嗯,我看了你的微博丫~\n小甲鱼:哟西~\n小客服:那个有条回复“左手拿著小甲魚,右手拿著打火機,哪裡不會點哪裡,so easy ^_^”\n小甲鱼:T_T\n================================================================================\n小客服:小甲鱼,今天一个会员想找你\n小甲鱼:哦?什么事?\n小客服:他说你一个学生月薪已经超过12k了!!\n小甲鱼:哪里的?\n小客服:上海的\n小甲鱼:那正常,哪家公司?\n小客服:他没说呀。\n小甲鱼:哦\n小客服:老大,为什么我工资那么低啊??是时候涨涨工资了!!\n小甲鱼:啊,你说什么?我在外边呢,这里好吵吖。。。。。。\n小客服:滚!!!'
>>> f.read(5)
''
>>> f.close()
>>> f = open ('D:\\PythonWenjian\\xiaojiayu\\record.txt')
>>> f.read(5)
'小客服:小'
>>> f.readline()
'甲鱼,今天有客户问你有没有女朋友?\n'
>>> f.tell()
45
3 os模块中关于文件/目录常用的函数使用方法(使用之前应该先导入import os)
getcwd() 返回当前工作目录
chdir() 改变工作目录
listdir(path='.') 列举指定目录中的文件名(‘.’表示当前目录,‘..’表示上一级目录)
mkdir() 创建单层目录,如该目录已存在抛出异常
makedirs(path) 递归创建多层目录,如该目录已存在抛出异常
remove(path) 删除文件
rmdir(path) 删除单层目录,如该目录非空抛出异常
removedirs(path) 递归删除目录,从子目录到父 目录逐层尝试删除,遇到目录非空则抛出异常
rename(old,new) 将文件old重命名为new
walk(top) 遍历top路径一下所有的子目录,返回一个三元组:(路径,[包含目录],[包含文件])
4 os.path模块中关于路径常用的函数使用方法
basename(path) 去掉目录路径,单独返回文件名
dirname(path) 去掉文件名,单独返回目录路径
join(path1,path2) 将path1、path2 各部分合成一个路径名
split(path) 分割文件名和路径,返回(f_path,f_name)元组,如果完全使用目录,它也会将最后一个目录作为文件名分离,且不会判断文件或者目录是否存在
splitext(path) 分离文件名与扩展名,返回(f_name,f_extension)元组
getsize(file) 返回指定文件的尺寸,单位是字节
getatime(file) 返回指定文件最近的访问时间(浮点型秒数,可用time模块的gmtime()或localtime()函数换算)
getctime(file) 返回指定文件的创建时间(浮点型秒数,可用time模块的gmtime()或localtime()函数换算)
getmtime(file) 返回指定文件最新的修改时间(浮点型秒数,可用time模块的gmtime()或localtime()函数换算)
以下函数返回True/False
exists(path) 判断指定路径(目录或文件)是否存在
isabs(path) 判断指定路径是否为绝对路径
isdir(path) 判断指定路径是否存在且是一个目录
isfile(path) 判断指定路径是否是存在且是一个文件
samefile(path1,path2) 判断path1和path2两个路径是否指向同一个文件
5 windows路径中既可以接受斜线(/),也接受反斜线(\),用反斜线时要用双反斜线(\\)
6 pickle模块
pickle的实质就是利用一些算法将你的数据对象腌制成二进制文件,存储在磁盘上,当然也可以放在数据库或者通过网络传输到另一台计算机上
pickle.dump(data,file):第一个参数是待存储的数据对象,第二个参数是目标存储的文件对象,注意要先使用‘wb’模式open文件
pickle.load(file) :参数是目标存储的文件对象,注意要先使用‘rb’的模式open文件
import pickle
#写入
my_dict = {'a':1,'c':3,'b':2}
pickle_file = open('my_dict.pkl','wb')
pickle.dump(my_dict,pickle_file)
pickle_file.close()
#读取
pickle_file = open('my_dict.pkl','rb')
my_dict2 = pickle.load(pickle_file)
print(my_dict2)