当前位置: 首页 > news >正文

Ubuntu 22.04中解决Could not load the Qt platform plugin “xcb“问题解决方法

摘要:在Ubuntu 22.04中安装OpenCV后,遇到“load the Qt platform plugin “xcb” in site-packages/cv2/qt/plugins" even though it was found. 的问题,导致程序无法启动。本文详细探讨了该问题的成因,并介绍了几种常见但无效的解决方法,包括设置环境变量、重装OpenCV或PySide6、以及降低OpenCV或Qt版本等。这些方法未能处理系统中缺失的XCB相关依赖项。最终,本文通过命令sudo apt install libxcb-*来安装所有与XCB相关的库,从而成功解决问题。


1. 引言

在Linux环境下,尤其是使用Ubuntu时,我们经常会选择OpenCV来进行图像处理和计算机视觉开发。最近,我在Ubuntu 22.04中安装OpenCV并运行代码时,遇到了一个比较棘手的问题——“Could not load the Qt platform plugin ‘xcb’”。这个问题直接导致程序无法启动,尽管系统已经找到了相应的插件。经过多次尝试和研究,我终于找到了一个有效的解决方案。在这篇博客中,我细介绍这个问题的解决过程,希望能帮助到同样遇到此问题的开发人员。


2. 错误描述

首先说一下,我的项目中使用了PyTorch、OpenCV和PySide6这些库,其实就是使用QT界面显示深度学习的一些项目。在Windows中运行良好,但同样的代码,在安装完OpenCV并尝试在ubuntu上运行时,终端报出了以下错误:

load the Qt platform plugin "xcb" in "/home/mindcraft/miniconda3/envs/env_rec/lib/python3.10/site-packages/cv2/qt/plugins" 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: vkkhrdisplay, xcb, minimal, wayland, minimalegl, wayland-egl, linuxfb, vnc, offscreen, eglfs.

从错误信息来看,问题的核心在于Qt无法加载xcb平台插件,即使系统已经找到了这个插件。这个问题比较奇怪,因为这个错误很容易以为是PyQt5或者PySide6的库报出来的。一般QT的环境变量没有设置好,也会提示说不能载入插件。

在这里插入图片描述

但仔细看这个错误是OpenCV报出来的,提示信息里面的“cv2/qt/plugins”就是OpenCV。我又想到会不会是PySide6的QT环境变量与OpenCV的相互影响了?找了一通,被很多教程给误导,没能解决。


3. 常见但无效的解决方法

在尝试解决这个问题的过程中,找到了很多以下常见但无效的解决方法:

  1. 设置环境变量
    很多教程建议设置环境变量export QT_QPA_PLATFORM=xcb,以确保Qt使用正确的插件,或者设置成vkkhrdisplay, xcb, minimal, wayland, minimalegl, wayland-egl, linuxfb, vnc, offscreen, eglfs这些其中的任一个。然而,尽管设置了这个变量,问题依然存在,并没有实质性的改善。这是因为该设置只是指示Qt使用特定的平台插件,而并未解决插件初始化失败的根本问题。

  2. 安装基础库
    常见的做法是安装一些与XCB相关的基础库,如:

    sudo apt-get install libxcb1 libxcb-util1 libx11-xcb1 libxrender1 libxrandr2 libxi6
    

    虽然这些库的安装可能会解决某些依赖性问题,但由于没有涵盖所有XCB相关的依赖项,因此大多数情况下问题依然存在。

  3. 重装OpenCV或重装PySide6
    尝试通过重新安装OpenCV或重装PySide6来解决问题,命令如下:

    pip uninstall opencv-python
    pip install PySide6
    pip install opencv-python
    pip install PySide6
    

    虽然重新安装OpenCV可以确保所有OpenCV组件被正确配置,但由于问题的根源在于Qt和XCB的依赖性,而非OpenCV本身,所以这种方法通常不会解决问题。

  4. 降低OpenCV或Qt版本
    一些开发者可能会尝试通过降低OpenCV或Qt的版本来解决兼容性问题。然而,这种方法也没有奏效,更换版本有时甚至会引入其他问题,导致新的兼容性问题。


4. 最终有效的解决方案

经过一番深入的探索,最终找到了一个有效的解决方案,即通过以下命令安装所有与libxcb相关的库:

sudo apt install libxcb-*

这条命令会安装所有以libxcb为前缀的库,确保系统中所有与XCB相关的依赖项都被正确安装。这一步成功解决了Qt无法加载xcb插件的问题,程序也顺利启动并运行。这表明,问题的根源在于某些关键的XCB依赖项缺失,而通过这种“一网打尽”的方式,我们可以确保所有相关的依赖项都得到满足。

在这里插入图片描述

这时再次运行py程序,我久违的界面就出现了。返回去看应该是某些关键的XCB依赖项缺失了,用这个命令正好安装了其中所需的。至于具体是哪个起到了作用,还真是难说,不过问题是解决了。

在这里插入图片描述


7. 参考资料

  • Qt Documentation
  • Ubuntu Packages
  • XCB Documentation
  • solved: Could not load the Qt platform plugin “xcb”

如果你在解决类似问题时有其他见解或想法,欢迎在评论区分享!希望这篇文章对你有所帮助。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 一条微博,让联想少卖16亿?
  • 软件测试用例的编写(六)
  • 嵌入式和单片机有什么区别?
  • 回归预测|基于灰狼GWO优化BP神经网络多输入多输出的数据回归预测Matlab程序GWO-BP 含预测新数据程序
  • RK3568开发笔记-buildroot系统scp拷贝文件报错dbclient no such file or directory
  • QT 目录
  • 学习node.js 七 http 模块
  • 回归分析系列19— 多项式回归进阶
  • Kubernetes 中如何对 etcd 进行备份和还原
  • AI 未来两年:史无前例的变革与挑战
  • 《图解设计模式》笔记(四)分开考虑
  • 2024.8.23
  • SolidityFoundry Merkle Airdrop
  • Python TensorFlow进阶篇
  • 安科瑞AEM系列碳排放碳结算计量电表产品介绍
  • CentOS学习笔记 - 12. Nginx搭建Centos7.5远程repo
  • ES6, React, Redux, Webpack写的一个爬 GitHub 的网页
  • JavaScript设计模式系列一:工厂模式
  • Mocha测试初探
  • mysql 数据库四种事务隔离级别
  • Netty+SpringBoot+FastDFS+Html5实现聊天App(六)
  • react-core-image-upload 一款轻量级图片上传裁剪插件
  • Redis 中的布隆过滤器
  • SpringBoot几种定时任务的实现方式
  • vue的全局变量和全局拦截请求器
  • 力扣(LeetCode)965
  • 模仿 Go Sort 排序接口实现的自定义排序
  • 正则表达式
  • 通过调用文摘列表API获取文摘
  • ​业务双活的数据切换思路设计(下)
  • #mysql 8.0 踩坑日记
  • #WEB前端(HTML属性)
  • (1)bark-ml
  • (11)工业界推荐系统-小红书推荐场景及内部实践【粗排三塔模型】
  • (ctrl.obj) : error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MDd_DynamicDebug”不匹配值“
  • (C语言)深入理解指针2之野指针与传值与传址与assert断言
  • (编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通
  • (二十六)Java 数据结构
  • (二十四)Flask之flask-session组件
  • (附源码)spring boot智能服药提醒app 毕业设计 102151
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (五)大数据实战——使用模板虚拟机实现hadoop集群虚拟机克隆及网络相关配置
  • (一)eclipse Dynamic web project 工程目录以及文件路径问题
  • (转)Android学习系列(31)--App自动化之使用Ant编译项目多渠道打包
  • (转)利用PHP的debug_backtrace函数,实现PHP文件权限管理、动态加载 【反射】...
  • (转)使用VMware vSphere标准交换机设置网络连接
  • .NET Core IdentityServer4实战-开篇介绍与规划
  • .Net MVC + EF搭建学生管理系统
  • .NET 依赖注入和配置系统
  • [ CTF ]【天格】战队WriteUp- 2022年第三届“网鼎杯”网络安全大赛(青龙组)
  • [Algorithm][动态规划][子序列问题][最长递增子序列][摆动序列]详细讲解
  • [BZOJ] 3262: 陌上花开
  • [C++] 统计程序耗时
  • [CQOI 2010]扑克牌
  • [C语言][PTA基础C基础题目集] strtok 函数的理解与应用