极短时间内找出目录下所有带 vba 代码的 excel 文件,并把它们转换成没有 vba 代码的 excel 文件

64 天前
 chen1star

win11 中有一个文件目录,这个文件目录下有很多子目录以及子目录的子目录等等,在这些目录中有许多带 vba 代码的 excel 文件,也有许多不带 vba 的 excel 文件,大约几十万个,这些 excel 文件的版本不一样。现在需要编写一个程序,在极短时间内找出目录下所有带 vba 代码的 excel 文件,并把它们转换成没有 vba 代码的 excel 文件,保持原来的文件版本和原来的文件名,大家有什么好的方案?

1575 次点击
所在节点    Python
5 条回复
summerwar
64 天前
xlsm 文件检查压缩包中是否有 xl/vbaProject.bin 文件,xls 文件检查是否存在名为 _VBA_PROJECT 的流( Stream )

然后 Python 的 pywin32 接口直接打开,然后另存为下面的格式就好了。

# 51 = xlOpenXMLWorkbook (.xlsx)
# 56 = xlExcel8 (.xls)
greatbody
64 天前
这种问题建议直接问 AI ,然后自己迭代。V2EX 禁止放 AI 写的回答,所以大家也不敢贴代码。一楼的挺好,回答的是思路。你可以带着这个思路问 AI 。
tomczhen
64 天前
几十万个文件,极短,这应该是把这里当许愿池了。
newaccount
64 天前
你这是把咱们当大模型来用了?
极短时间,一秒钟处理十个文件够快了吧,要几万秒,我只知道一个小时才 3600 秒
R0Nnn
55 天前
1 楼方案的基础上加上并发,速度上限取决于机器性能

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

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

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

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

© 2021 V2EX