win11 中有一个文件目录,这个文件目录下有很多子目录以及子目录的子目录等等,在这些目录中有许多带 vba 代码的 excel 文件,也有许多不带 vba 的 excel 文件,大约几十万个,这些 excel 文件的版本不一样。现在需要编写一个程序,在极短时间内找出目录下所有带 vba 代码的 excel 文件,并把它们转换成没有 vba 代码的 excel 文件,保持原来的文件版本和原来的文件名,大家有什么好的方案?
![]() |
1
summerwar 18 天前
xlsm 文件检查压缩包中是否有 xl/vbaProject.bin 文件,xls 文件检查是否存在名为 _VBA_PROJECT 的流( Stream )
然后 Python 的 pywin32 接口直接打开,然后另存为下面的格式就好了。 # 51 = xlOpenXMLWorkbook (.xlsx) # 56 = xlExcel8 (.xls) |
![]() |
2
greatbody 18 天前
这种问题建议直接问 AI ,然后自己迭代。V2EX 禁止放 AI 写的回答,所以大家也不敢贴代码。一楼的挺好,回答的是思路。你可以带着这个思路问 AI 。
|
![]() |
3
tomczhen 18 天前 ![]() 几十万个文件,极短,这应该是把这里当许愿池了。
|
![]() |
4
newaccount 17 天前
你这是把咱们当大模型来用了?
极短时间,一秒钟处理十个文件够快了吧,要几万秒,我只知道一个小时才 3600 秒 |
5
R0Nnn 8 天前 via iPhone
1 楼方案的基础上加上并发,速度上限取决于机器性能
|