V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
一键将照片转化为漫画插画
可一键将生活照转化为吉卜力风格、漫画风格、Q版头像风格等风格照,支持GPT4o,Veo3,可灵,Flux.1 Kontext等先进模型
Promoted by johnwayne
chen1star
V2EX  ›  Python

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

  •  
  •   chen1star · 18 天前 · 1225 次点击

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

    5 条回复    2025-07-18 13:24:48 +08:00
    summerwar
        1
    summerwar  
       18 天前
    xlsm 文件检查压缩包中是否有 xl/vbaProject.bin 文件,xls 文件检查是否存在名为 _VBA_PROJECT 的流( Stream )

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

    # 51 = xlOpenXMLWorkbook (.xlsx)
    # 56 = xlExcel8 (.xls)
    greatbody
        2
    greatbody  
       18 天前
    这种问题建议直接问 AI ,然后自己迭代。V2EX 禁止放 AI 写的回答,所以大家也不敢贴代码。一楼的挺好,回答的是思路。你可以带着这个思路问 AI 。
    tomczhen
        3
    tomczhen  
       18 天前   ❤️ 1
    几十万个文件,极短,这应该是把这里当许愿池了。
    newaccount
        4
    newaccount  
       17 天前
    你这是把咱们当大模型来用了?
    极短时间,一秒钟处理十个文件够快了吧,要几万秒,我只知道一个小时才 3600 秒
    R0Nnn
        5
    R0Nnn  
       8 天前 via iPhone
    1 楼方案的基础上加上并发,速度上限取决于机器性能
    关于   ·   帮助文档   ·   自助推广系统   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2499 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 18ms · UTC 05:04 · PVG 13:04 · LAX 22:04 · JFK 01:04
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.