目的: 将一个txt内容逐行分发n个txt中
完整代码如下:
def fenFa(num,file_num):#定义初始值,需要分发文件个数
with open('data1.txt', 'r') as file1:#打开文件
lines = file1.readlines()#读取文件内容
lenth = len(lines)#获取内容个数
for line in lines:#循环file1内数据
if num < file_num: # 判断初始值是否小于要分的文件个数
with open(f'data_{num}.txt', 'a') as file: # 写入不同的目标文件
file.write(f'{line}') # 写入目标内容
num = num + 1#写入完成后,初始值+1,以便写入下个目标文件
else:
with open(f'data_{num}.txt', 'a') as file: # 写入不同的目标文件
file.write(f'{line}') # 写入目标内容
num = 1#回归初始值
fenFa(1,2)#初始值,目标文件个数
思路:
- 获取原文件数据及个数
- 对n个txt循环写入数据:先对首个数据写入完成后,结束当前写入,初始值+1,进入下个数据写入,同时更改目标文件名
问题:
- 更换原始数据后,已分发写入的文件需要手动删除
- 下面此处代码如何才能更简洁,能否将else下的写入放入if中,暂未想到
for line in lines:#循环file1内数据
if num < file_num: # 判断初始值是否小于要分的文件个数
with open(f'data_{num}.txt', 'a') as file: # 写入不同的目标文件
file.write(f'{line}') # 写入目标内容
num = num + 1#写入完成后,初始值+1,以便写入下个目标文件
else:
with open(f'data_{num}.txt', 'a') as file: # 写入不同的目标文件
file.write(f'{line}') # 写入目标内容
num = 1#回归初始值
其他方法:
- 可以通过循环取余的方式实现该目的