PyroSAR 安装后出现 “No module named _gdal_array”

最近在给项目环境安装 PyroSAR 时遇到一个 GDAL 依赖问题,运行脚本时直接报错:

ModuleNotFoundError: No module named '_gdal_array'

这个错误最直观的表现就是 GDAL 的 Python 扩展模块没加载成功,而 _gdal_array 正好属于 GDAL 的底层二进制扩展。PyroSAR 本身依赖 GDAL,如果这个模块缺失,不管是读写 GeoTIFF、解析元数据还是处理 SAR 数据,都会全部失败。

我一开始以为是 PyroSAR 装坏了,但检查之后发现问题根本不在 PyroSAR,而是系统里的 GDAL 安装并不完整。Python 在 import gdal_array 时能找到纯 Python 的接口文件,却找不到对应的 _gdal_array.so 扩展文件,多半是被之前的版本覆盖、或者 pip 缓存里存了残缺的 wheel,导致 GDAL 的 Python Bindings 不完整。

实际解决方式很简单,就是把 GDAL 彻底重装一遍,不过不能直接 pip install,需要让 pip 强制抛弃所有本地缓存,把 GDAL 完整重新编译。

使用 uv 的方式如下:

uv pip install setuptools wheel

uv pip install --force-reinstall --no-cache-dir --no-build-isolation gdal==3.4.1

装完之后,再运行同样的代码,问题就消失了。

为什么这样做有效呢?

主要是因为 GDAL 的 Python 模块是由一部分 Python 文件和一部分 C++ 编译的二进制扩展共同组成的,而 _gdal_array 就属于后者。只要编译产物版本不一致或者缺失,这个错误就必然出现。重新安装 GDAL 时加上 --force-reinstall 可以把旧版本全部覆盖,--no-cache-dir 能避免 pip 使用错误的缓存,--no-build-isolation 则让构建过程直接使用当前环境的编译链,不再被隔离环境影响。最终生成的 GDAL 扩展文件是完整的,Python 也就可以正常加载 _gdal_array 了。

GDAL 3.4.1 这个版本和 PyroSAR 的兼容性比较稳,所以指定版本能少踩很多坑。

整个问题本质上就是 GDAL 的 Python Bindings 装得不干净。PyroSAR 只是把问题暴露出来了,重新构建 GDAL 则把文件补齐了。这样的小坑在地理数据相关的 Python 环境里算是家常便饭,也算是一次记录下来给后续查环境的人少走弯路。

相关推荐
八零后琐话34 分钟前
干货:程序员必备性能分析工具——Arthas火焰图
开发语言·python
青春不朽5122 小时前
Scrapy框架入门指南
python·scrapy
MZ_ZXD0012 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
全栈老石3 小时前
Python 异步生存手册:给被 JS async/await 宠坏的全栈工程师
后端·python
梨落秋霜3 小时前
Python入门篇【模块/包】
python
阔皮大师4 小时前
INote轻量文本编辑器
java·javascript·python·c#
小法师爱分享4 小时前
StickyNotes,简单便签超实用
java·python
深蓝电商API4 小时前
处理字体反爬:woff字体文件解析实战
爬虫·python
开源技术4 小时前
Claude Opus 4.6 发布,100万上下文窗口,越贵越好用
人工智能·python