解决在 Docker 中启动 labelImg 的相关报错

文章目录

  • 一、简介
  • [二、libGL 报错&解决方法](#二、libGL 报错&解决方法)
  • [三、xcb 插件报错&解决方法](#三、xcb 插件报错&解决方法)
  • 小结

一、简介

  1. 本文提到的报错信息,是在 ubuntu-22.04 中通过 miniconda3 创建的 python-3.10 版本的虚拟环境下安装的labelImg提示的报错。推荐使用 conda 指令安装:conda install -c conda-forge labelimg -y,使用 pip 安装就会有下面的各类报错信息。

  2. 参考如下版本信息,如果有相关的报错可以参考本文的解决方法。部分问题也可以通过 减低版本 来解决,需要具体情况具体分析。这里不保证完全有效,仅供参考。

    bash 复制代码
    # Name                    Version                   Build  Channel
    _libgcc_mutex             0.1                        main  
    _openmp_mutex             5.1                       1_gnu  
    bzip2                     1.0.8                h5eee18b_6  
    ca-certificates           2025.12.2            h06a4308_0  
    expat                     2.7.3                h7354ed3_4  
    labelimg                  1.8.6                    pypi_0    pypi
    ld_impl_linux-64          2.44                 h153f514_2  
    libexpat                  2.7.3                h7354ed3_4  
    libffi                    3.4.4                h6a678d5_1  
    libgcc                    15.2.0               h69a1729_7  
    libgcc-ng                 15.2.0               h166f726_7  
    libgomp                   15.2.0               h4751f2c_7  
    libnsl                    2.0.0                h5eee18b_0  
    libstdcxx                 15.2.0               h39759b7_7  
    libstdcxx-ng              15.2.0               hc03a8fd_7  
    libuuid                   1.41.5               h5eee18b_0  
    libxcb                    1.17.0               h9b100fa_0  
    libzlib                   1.3.1                hb25bd0a_0  
    lxml                      6.0.2                    pypi_0    pypi
    ncurses                   6.5                  h7934f7d_0  
    openssl                   3.0.18               hd6dcaed_0  
    pip                       25.3               pyhc872135_0  
    pthread-stubs             0.3                  h0ce48e5_1  
    pyqt5                     5.15.11                  pypi_0    pypi
    pyqt5-qt5                 5.15.18                  pypi_0    pypi
    pyqt5-sip                 12.17.2                  pypi_0    pypi
    python                    3.10.19              h6fa692b_0  
    readline                  8.3                  hc2a1206_0  
    setuptools                80.9.0          py310h06a4308_0  
    sqlite                    3.51.0               h2a70700_0  
    tk                        8.6.15               h54e0aa7_0  
    tzdata                    2025b                h04d1e81_0  
    wheel                     0.45.1          py310h06a4308_0  
    xorg-libx11               1.8.12               h9b100fa_1  
    xorg-libxau               1.0.12               h9b100fa_0  
    xorg-libxdmcp             1.1.5                h9b100fa_0  
    xorg-xorgproto            2024.1               h5eee18b_1  
    xz                        5.6.4                h5eee18b_1  
    zlib                      1.3.1                hb25bd0a_0  

二、libGL 报错&解决方法

  1. 容器是精简版的 Linux,默认没有 libGL 图形驱动库,所以会提示找不到文件。

    bash 复制代码
    Traceback (most recent call last):
    
      File "/opt/miniconda3/envs/labelImg/lib/python3.10/site-packages/labelImg/labelImg.py", line 18, in <module>
    
        from PyQt5.QtGui import *
    
    ImportError: libGL.so.1: cannot open shared object file: No such file or directory
    
    During handling of the above exception, another exception occurred:
    
    Traceback (most recent call last):
    
      File "/opt/miniconda3/envs/labelImg/bin/labelImg", line 3, in <module>
    
        from labelImg.labelImg import main
    
      File "/opt/miniconda3/envs/labelImg/lib/python3.10/site-packages/labelImg/labelImg.py", line 27, in <module>
    
        import sip
    
    ModuleNotFoundError: No module named 'sip'
  2. 执行如下指令解决上述 libGL 报错。

    bash 复制代码
    apt update && apt install -y libgl1-mesa-glx libglib2.0-0 libx11-xcb1
  3. 执行如下指令解决上述 python 依赖,其实在安装 labelimg 的时候已经安装过了。

    bash 复制代码
    # 1. 先安装 pyqt5 相关的 sip
    pip install PyQt5-sip
    
    # 2. 重新安装 pyqt5 (确保版本完整)
    pip install PyQt5
    
    # 3. 如果依然报错,尝试安装特定版本的 lxml
    pip install lxml
  4. 需要注意,容器内指定的显示器编号需要和宿主机一致,并且需要具有权限可视化,应最先确认如下信息。

    bash 复制代码
    echo $DISPLAY  # 获取宿主机显示器编号
    echo "export DISPLAY=:1" >> ~/.bashrc  # 在容器内指定相同编号,以 1 为例   

三、xcb 插件报错&解决方法

  1. 报错 xcb 插件加载失败,是因为 PyQt5 运行所需的底层 XCB 相关库在容器内还不完整。

    bash 复制代码
    qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in "" even though it was found.
    
    This application failed to start because no Qt platform plugin could be initialized. Reinstalling the application may fix this problem.
    
    Available platform plugins are: eglfs, linuxfb, minimal, minimalegl, offscreen, vnc, wayland-egl, wayland, wayland-xcomposite-egl, wayland-xcomposite-glx, webgl, xcb.
    
    Aborted (core dumped)
  2. 执行如下指令,补齐 Qt5 缺失的所有 xcb 依赖。

    bash 复制代码
    apt update && apt install -y \
        libxcb-xinerama0 \
        libxcb-icccm4 \
        libxcb-image0 \
        libxcb-keysyms1 \
        libxcb-render-util0 \
        libxcb-xfixes0 \
        libxcb-shape0 \
        libxcb-randr0 \
        libxkbcommon-x11-0 \
        libdbus-1-3

小结

以上内容作为错误记录,仅供参考,不保证完全有效。如有其他问题欢迎在评论区讨论!!

相关推荐
是火云哦1 天前
打包你的开发环境:Docker 从入门到上瘾
运维·docker·容器
小明_GLC1 天前
关于租用阿里云服务器拉取Docker镜像的问题
docker
今晚打佬虎1 天前
精准阻断 Docker 容器映射端口:流量路径诊断与 iptables 配置
运维·docker·容器
那年一路北1 天前
基于 Maven + Docker 的 WebApp 打包与部署
docker·maven·web app
阡陌..1 天前
Linux下用docker调用pytorch-无法检测到cuda问题
linux·pytorch·docker
KubeSphere 云原生1 天前
在 KubeSphere 上运行 Moltbot(Clawdbot):自托管 AI 助手的云原生实践
docker·云原生·容器
你才是臭弟弟1 天前
生产环境开箱即用的“Flink + Iceberg 数据湖容器搭建”(Docker)
docker·容器·jar
爱技术的小伙子1 天前
【 Docker 快速部署 MySQL 8.0(2026最新实践)—— 一键启动 + 数据持久化 + 常见优化】
mysql·adb·docker
hunter14501 天前
docker 在centos和ubuntu的安装
linux·docker·centos
不做码农好多年,该何去何从。1 天前
阿里云上使用docker-compose安装禅道
阿里云·docker·云计算