【Python】常用文件操作
程序员文章站
2022-06-06 21:01:38
对文件内容操作:file= open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)file.read([size]) #size为读取的长度,以byte为单位file.readline([size]) #读一行,如果定义了size,有可能返回的只是一行的一部分file.readlines([size]) #把文件每一行作为一个list的一个成员...
对文件内容操作:
file= open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)
file.read([size]) #size为读取的长度,以byte为单位
file.readline([size]) #读一行,如果定义了size,有可能返回的只是一行的一部分
file.readlines([size]) #把文件每一行作为一个list的一个成员,并返回这个list。其实它的内部是通过循环调用readline()来实现的。如果提供size参数,size是表示读取内容的总长,也就是说可能只读到文件的一部分。
file.tell() #返回文件操作标记的当前位置,以文件的开头为原点
file.next() #返回下一行,并将文件操作标记位移到下一行。
file.seek(offset[,whence]) #将文件打操作标记移到offset的位置。这个offset一般是相对于文件的开头来计算的,一般为正数。但如果提供了whence参数就不一定了。whence可以为0,表示从头开始计算;可以为1表示,以当前位置为原点计算;可以为2,表示以文件末尾为原点进行计算。需要注意,如果文件以a或a+的模式打开,每次进行写操作时,文件操作标记会自动返回到文件末尾。
file.write(str) #把str写到文件中,write()并不会在str后加任何东西
file.writelines(seq) # 一次性写一个list,不会在每个item后面加任何东西
file.close() #关闭文件。python会在一个文件不用后自动关闭文件,不过这一功能没有保证,最好还是养成自己关闭的习惯。 如果一个文件在关闭后还对其进行操作会产生ValueError
file.flush() #把缓冲区的内容写入硬盘
file.fileno() #返回一个长整型的”文件标签“
file.isatty() #文件是否是一个终端设备文件(unix系统中的)
时,就是调用next()函数来实现遍历的。
对目录操作:
#创建文件夹:
os.mkdir("file")
#复制文件:
shutil.copyfile("oldfile","newfile") #oldfile和newfile都只能是文件
#复制文件夹:
shutil.copytree("olddir","newdir") #olddir和newdir都只能是目录,且newdir必须不存在
#重命名文件
os.rename("oldname","newname") #文件或目录都是使用这条命令
#移动文件
shutil.move("file","dir")
#删除文件
os.remove("file")
#删除目录
os.rmdir("dir") #只能删除空目录
shutil.rmtree("dir") #空目录、有内容的目录都可以删
#转换目录
os.chdir("path") #修改当前路径
os模块中的文件操作:
os.path.isdir(name) #判断name是不是一个目录,name不是目录就返回false
os.path.isfile(name) #判断name是不是一个文件,不存在name也返回false
os.path.exists(name) #判断是否存在文件或目录name
os.path.getsize(name) #获得文件大小,单位字节,如果name是目录返回0
os.path.abspath(name) #获得绝对路径
os.path.split(name) #分割文件名与目录(仅仅是把路径中最后一个/的后面部分分离开而已)
os.path.splitext() #分离文件名与扩展名(仅仅是把路径中最后一个.的后面部分分离开而已)
os.path.join(path,name) # 连接目录与文件名或目录
os.path.basename(path) # 返回文件名(仅仅是返回路径中最后一个/的后面部分而已)
os.path.dirname(path) # 返回文件路径(仅仅是返回路径中最后一个/的前面部分而已)
#列出目录下的文件:
os.listdir(path) # 仅仅是一层深度,不会递归子文件夹
#获取当前工作目录:
os.getcwd()
#创建多级目录:
os.makedirs(r"c:\python\test") # 如果以/开头,则指的是当前磁盘的根目录
#删除多个目录:
os.removedirs(r"hahah/xixixi/mmm") # 递归删除空文件夹。先尝试删除mmm文件夹,然后尝试删除xixixi文件夹,最后删除hahah文件夹
#删除单个空目录:
os.rmdir("test")
#获取文件属性:
os.stat(file)
参考:
https://www.cnblogs.com/claudia/p/9988624.html
https://www.cnblogs.com/wkjava/p/12640426.html
本文地址:https://blog.csdn.net/zxc120389574/article/details/107144591
上一篇: 循环队列