Python3 解决文件 save 多次出现空文件

最近项目中需要做批量上传日报的功能,照片只拍一张,所有的日报共用,要保存多份,所以在迭代的时候就直接使用

file.save(filename)

进行保存了

结果发现,从第二次开始保存的文件都是错误的,打不开。排查发现文件都是空的

后来想通了,这是因为文件在写入的过程中,指针也会随着向后指。所有等文件写入到磁盘,指针也指到了最后

所以就需要文件的指针指向初始状态即可

file.save(filename)
file.seek(0)

当然,在指针恢复在其他场景也会遇到的比如

file.read()
file.save()

诸如此类,但凡有文件或者数据流等等需要用到指针的地方,存储多次都需要将指针指向初始状态

实现多个Excel文件合并的方法主要有两种,一种是使用Python的pandas库,另一种是使用xlrd和xlwt库。 下面分别介绍这两种方法的实现步骤: 1. 使用pandas库 首先需要安装pandas库,可以使用pip install pandas命令进行安装。 合并Excel文件的步骤如下: ① 导入pandas库和os库 ```python import pandas as pd import os ``` ② 定义一个函数,用于将多个Excel文件合并为一个DataFrame对象 ```python def merge_excels(path): result = pd.DataFrame() for root, dirs, files in os.walk(path): for file in files: if file.endswith('.xlsx'): # 只处理xlsx文件 file_path = os.path.join(root, file) df = pd.read_excel(file_path) result = result.append(df) return result ``` ③ 调用merge_excels函数,将多个Excel文件合并为一个DataFrame对象,并将结果保存到一个新的Excel文件中 ```python path = '/path/to/excels' result = merge_excels(path) result.to_excel('merged.xlsx', index=False) ``` 2. 使用xlrd和xlwt库 需要先安装xlrd和xlwt库,可以使用pip install xlrd xlwt命令进行安装。 合并Excel文件的步骤如下: ① 导入xlrd和xlwt库 ```python import xlrd import xlwt import os ``` ② 定义一个函数,用于将多个Excel文件合并为一个新的Excel文件 ```python def merge_excels(path): wb = xlwt.Workbook(encoding='utf-8') ws = wb.add_sheet('merged') row_num = 0 for root, dirs, files in os.walk(path): for file in files: if file.endswith('.xlsx'): # 只处理xlsx文件 file_path = os.path.join(root, file) workbook = xlrd.open_workbook(file_path) sheet = workbook.sheet_by_index(0) if row_num == 0: # 第一次循环需要写入表头 for i in range(sheet.ncols): ws.write(row_num, i, sheet.cell_value(0, i)) row_num += 1 for j in range(1, sheet.nrows): # 从第二行开始写入数据 for k in range(sheet.ncols): ws.write(row_num, k, sheet.cell_value(j, k)) row_num += 1 return wb ``` ③ 调用merge_excels函数,将多个Excel文件合并为一个新的Excel文件,并保存到本地 ```python path = '/path/to/excels' wb = merge_excels(path) wb.save('merged.xls') ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值