请教个 pandas 问题, excel 某一列是包含货币样式的公式,pandas.read_excel 得到的结果全是 0...

138 天前
 demonps

写入如下:

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(...)

891 次点击
所在节点    Python
2 条回复
NoOneNoBody
138 天前
前置:不熟悉 excel ,可能楼下其他答案更佳

write 使用特定 engine 时,read 也要指定 engine ,而且你这个金额都是 str ,也要考虑 dtype 问题,thousands 参数好象是做这事的,但可能更有效是这个 engine 相关的参数 engine_kwargs
demonps
138 天前
感谢回复
金额列长这样
=K2*G2/100/100
=((H2-G2)*L2+(I2-G2)*M2+(J2-G2)*N2) / 100 / 100

给他设置了货币格式之后读到的就全是 0 了~~,试过设置 dtype,不太行. engine 因为 xlsxwriter 是个写 excel 的 lib 不支持读的

我去看看那个 thousands

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1003346

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX