Python日常笔记(14)-IO/文件备份

文件操作

open() 方法
注意:使用 open() 方法一定要保证关闭文件对象,即调用 close() 方法。
open() 函数常用形式是接收两个参数:文件名(file)和模式(mode)。

open(file, mode='r')

完整的语法格式为:

open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

参数说明:

file: 必需,文件路径(相对或者绝对路径)。

mode: 可选,文件打开模式

buffering: 设置缓冲

encoding: 一般使用utf8

errors: 报错级别

newline: 区分换行符

closefd: 传入的file参数类型

opener:

mode的模式可以到菜鸟教程上去详细了解

注意:所有带b的都是读取二进制形式

# 1.打开文件
f = open("test.txt", "w")
# 2.写文件
f.write("11111")
# 3.关闭资源
f.close()

# 1.打开文件
f = open("test.txt", "r")
# 2.读文件
str = f.read()
print(str)
# 3.关闭资源
f.close()

# 1.打开文件
f = open("test.txt", "a")
# 2.追加文件内容
f.write("ttttttt")
print(str)
# 3.关闭资源
f.close()

Open()
Open函数是打开文件并且创建一个file对象

file对象常用函数

file.close()
关闭文件。关闭后文件不能再进行读写操作。

file.flush()
刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。

file.fileno()
返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。

file.isatty()
如果文件连接到一个终端设备返回 True,否则返回 False。

file.next()
Python 3 中的 File 对象不支持 next() 方法。

返回文件下一行。
file.read([size])
从文件读取指定的字节数,如果未给定或为负则读取所有。

file.readline([size])
读取整行,包括 “\n” 字符。

file.readlines([sizeint])
读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区。

file.seek(偏移量,起始位置)
移动文件读取指针到指定位置
注意:如果使用a+模式来读取数据是读取不出来的,因为读取的指针在数据最末尾,需要使用seek函数来改变指针的位置
起始位置:0:文件开头,1:文件当前位置,2:文件结尾位置

file.tell()
返回文件当前位置。

file.truncate([size])
从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后后面的所有字符被删除,其中 Widnows 系统下的换行代表2个字符大小。

file.write(str)
将字符串写入文件,返回的是写入的字符长度。

file.writelines(sequence)
向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。

写几个常用实例

# 1.打开文件
f = open("test.txt", "w")
# 2.写文件
f.write("11111")
# 3.关闭资源
f.close()

# 1.打开文件
f = open("test.txt", "r")
# 2.读文件
str = f.read()
print(str)
# 3.关闭资源
f.close()

# 1.打开文件
f = open("test.txt", "a")
# 2.追加文件内容
f.write("ttttttt")
print(str)
# 3.关闭资源
f.close()

# readlines读取所有数据,存进序列
f = open("test.txt", "r")
list1 = f.readlines()
print(list1)
f.close()

# readline读取一行数据
f = open("test.txt", "r")
list1 = f.readline()
print(list1)
f.close()

文件备份

实例

# 1.用户输入目标文件名称
old_name = input("请输入目标文件名:")

# 2.制定新规则的文件名xxx[备份].xxx
index = old_name.rfind(".")
new_name = old_name[0:index] + "[备份]" + old_name[index:]

# 3.创建读和写的file对象
read_file = open(old_name, "rb")
write_file = open(new_name, "wb")

while True:
   data = read_file.read(10)
   if len(data) == 0:
       break
   write_file.write(data)

#关闭流对象
read_file.close()
write_file.close()

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nhJp6jkY-1584951152728)(https://gitee.com/duchaochen/pythonnote/raw/master/img/20200323/1-3.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DZCLoi2E-1584951152729)(https://gitee.com/duchaochen/pythonnote/raw/master/img/20200323/1-4.png)]

文件和文件夹操作

使用os对象必须导入os模块
实例:

import os
# 1.os.rename(src, dst):重命名文件或目录,从 src 到 dst
os.rename("test.txt", "1.txt")
# 2.os.remove(path) 删除路径为path的文件或者一个空的文件夹否则将抛出OSError。
os.remove("1.txt")
# 4.os.mkdir(path[, mode]) 以数字mode的mode创建一个名为path的文件夹.默认的 mode 是 0777 (八进制)。
os.mkdir("aa")
# 3.os.rmdir(path) 删除path指定的空目录,如果目录非空,则抛出一个OSError异常。
os.rmdir("aa")
# 5.os.getcwd()返回当前工作目录
print(os.getcwd())
# 6.os.chdir(path)改变当前工作目录
# os.chdir("aa")
os.mkdir("bb")
# 7.os.listdir(path:默认值是当前目录) 返回path指定的文件夹包含的文件或文件夹的名字的列表。
print(os.listdir())
# 批量重命名小案例
flag = 2  # flag=1是直接将python_合并原有文件名来修改,flag=2是直接将python_删除掉
dirs = os.listdir()
for path_name in dirs:
   # 批量加上python_和原始名称合并
   if flag == 1:
       new_name = "Python_" + path_name
   else:
       new_name = path_name[len("Python_"):]
   os.rename(path_name, new_name)

作者:阿超
原创公众号:『Python日常笔记』,专注于 Python爬虫等技术栈和有益的程序人生,会将一些平时的日常笔记都慢慢整理起来,也期待你的关注和阿超一起学习,公众号回复【csdn】优质资源。

发布了55 篇原创文章 · 获赞 16 · 访问量 9510

猜你喜欢

转载自blog.csdn.net/duchaochen/article/details/105051028