写入如下:
with pd.ExcelWriter(file_name, engine='xlsxwriter') as writer:
fmt = writer.book.add_format({'num_format': '¥#,##0.00;[红色]¥ -#,##0.00'})
df.to_excel(writer, sheet_name='xxx', index=False)
writer.sheets['stats'].set_column('K:K', None, fmt)
读取就是简单的 pd.read_excel(...)
1
NoOneNoBody 2023-12-25 20:39:27 +08:00
前置:不熟悉 excel ,可能楼下其他答案更佳
write 使用特定 engine 时,read 也要指定 engine ,而且你这个金额都是 str ,也要考虑 dtype 问题,thousands 参数好象是做这事的,但可能更有效是这个 engine 相关的参数 engine_kwargs |
2
demonps OP 感谢回复
金额列长这样 =K2*G2/100/100 =((H2-G2)*L2+(I2-G2)*M2+(J2-G2)*N2) / 100 / 100 给他设置了货币格式之后读到的就全是 0 了~~,试过设置 dtype,不太行. engine 因为 xlsxwriter 是个写 excel 的 lib 不支持读的 我去看看那个 thousands |