报126之类的错误,多半是因为DLL引用链里面缺了某些dll,而不一定是第一个DLL找不到
如果你是win10,用pyinstaller打包,然后打出来的包里面没有api-ms-win-*.dll,那恭喜你,可能踩了个坑
微软的描述:
https://blogs.msdn.microsoft.com/vcblog/2015/03/03/introducing-the-universal-crt/
github上的issue:
https://github.com/pyinstaller/pyinstaller/issues/1566
大约是说,win10里面,这些dll是magic words,不是真正存在的dll,import的时候会自动跳转到别的逻辑去。但是win10以下的系统又真的要import这些dll,所以你如果在win10上面打包,在win10上面跑的话,没有这些dll也是ok的。但是如果在win10以下的系统跑的时候,就需要这些dll了,pyinstaller给出的解决方案是:https://github.com/pyinstaller/pyinstaller/pull/2821/files
- 在win7下面打包
- 在你的终端用户电脑上装vs2015redist
- 在打包机上装win10SDK https://developer.microsoft.com/en-us/windows/downloads/windows-10-sdk
第一点多半是OK的,但是比较强硬
第二点没试过,但是不符合开箱即用的要求
第三点可能是比较好的解决方案
事实上也有一个比较暴力的方案(也可能是第二点的某种黑实践),你全局搜索一下,你的电脑上装的很多软件都踩过这个坑,所以都会自带一套这些dll文件,你在打包的时候复制进去就好了。但是可能不是彻底解决问题的方法。