首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
Ubuntu安装PySide6开发桌面应用实践

Ubuntu安装PySide6开发桌面应用实践

热心网友
58
转载
2026-04-23

一、引言

最近在对接大模型测试任务时,需要开发一个Python桌面应用。于是,就有了这篇在WSL2的Ubuntu环境下配置PySide6开发环境的实战记录。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

二、Ubuntu非桌面端安装PySide6

理想情况下,在Ubuntu桌面系统里直接安装PySide6,再配上VSCode就能开干。但手头只有一台Windows机器,所以这次选择通过WSL2来模拟运行Ubuntu环境。

2.1、wsl2 Ubuntu安装基础工具

第一步,自然是安装包管理工具pip:

sudo apt update
sudo apt install python3-pip

接着,尝试用pip安装PySide6:

pip3   install PySide6
error: externally-managed-environment

× This environment is externally managed
╰─> To install Python packages system-wide, try apt install
    python3-xyz, where xyz is the package you are trying to
    install.

    If you wish to install a non-Debian-packaged Python package,
    create a virtual environment using python3 -m venv path/to/venv.
    Then use path/to/venv/bin/python and path/to/venv/bin/pip. Make
    sure you ha ve python3-full installed.

    If you wish to install a non-Debian packaged Python application,
    it may be easiest to use pipx install xyz, which will manage a
    virtual environment for you. Make sure you ha ve pipx installed.

    See /usr/share/doc/python3.12/README.venv for more information.

note: If you believe this is a mistake, please contact your Python installation or OS distribution provider. You can override this, at the risk of breaking your Python installation or OS, by passing --break-system-packages.
hint: See PEP 668 for the detailed specification.

这里遇到了第一个坎儿。错误信息很明确:Ubuntu系统出于安全考虑,遵循Python PEP 668规范,禁止直接用pip安装全局包,目的是保护系统Python环境的纯净。

解决办法也给出了提示:创建一个虚拟环境,然后在虚拟环境里安装。这其实是Python开发的最佳实践。

# 1. 创建虚拟环境(指定存放路径,比如 ~/pyside6_venv)
python3 -m venv ~/pyside6_venv
# 2. 激活虚拟环境(每次使用前都需要执行)
source ~/pyside6_venv/bin/activate

但创建虚拟环境时,又报错了:

python3 -m venv ~/pyside6_venvThe virtual environment was not created successfully because ensurepip is nota vailable. On Debian/Ubuntu systems, you need to install the python3-venvpackage using the following command.

apt install python3.12-venv

You may need to use sudo with that command. After installing the python3-venvpackage, recreate your virtual environment.

Failing command: /home/iqos/pyside6_venv/bin/python3​

原因也很直接:系统缺少创建Python虚拟环境所必需的python3.12-venv包。先把它装上:

sudo apt install python3.12-venv  -y

之后,再执行创建和激活虚拟环境的命令,就顺利通过了。

万事俱备,现在可以在激活的虚拟环境中安装PySide6了:

pip install PySide6
Collecting PySide6
  Downloading pyside6-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl.metadata (5.3 kB)
Collecting shiboken6==6.10.2 (from PySide6)
  Downloading shiboken6-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl.metadata (2.5 kB)
Collecting PySide6_Essentials==6.10.2 (from PySide6)
  Downloading pyside6_essentials-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl.metadata (3.7 kB)
Collecting PySide6_Addons==6.10.2 (from PySide6)
  Downloading pyside6_addons-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl.metadata (4.0 kB)
Downloading pyside6-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl (563 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 563.4/563.4 kB 979.5 kB/s eta 0:00:00
Downloading pyside6_addons-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl (170.7 MB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 170.7/170.7 MB 172.0 kB/s eta 0:00:00
Downloading pyside6_essentials-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl (77.0 MB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 77.0/77.0 MB 136.9 kB/s eta 0:00:00
Downloading shiboken6-6.10.2-cp39-abi3-manylinux_2_34_x86_64.whl (273 kB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 273.1/273.1 kB 26.2 kB/s eta 0:00:00
Installing collected packages: shiboken6, PySide6_Essentials, PySide6_Addons, PySide6
Successfully installed PySide6-6.10.2 PySide6_Addons-6.10.2 PySide6_Essentials-6.10.2 shiboken6-6.10.2

看到“Successfully installed”的提示,PySide6的安装就大功告成了。接下来,需要在Windows上安装VSCode,并配置它与WSL协同工作。

2.2、windows下安装VSCode

2.2.1、第一步:配置 WSL 支持 GUI 显示

# 在 WSL 终端执行
wsl --version  # 查看版本,确保有 WSLg 相关信息
wsl -l -v      # 检查 Ubuntu 发行版的版本是 2

如果检查发现Ubuntu发行版版本是1,需要执行wsl --set-version Ubuntu 2将其升级到WSL 2(这个过程可能需要几分钟)。

2.2.2、第二步: 安装 WSL 所需的 GUI 依赖(Ubuntu 端)

即便有了WSLg,要运行基于Qt的PySide6程序,仍然需要在Ubuntu侧安装一些基础的X11图形依赖库。

sudo apt update
sudo apt install -y libx11-6 libxcb1 libxkbcommon-x11-0 libgl1-mesa-glx

执行上述命令时,可能会遇到报错:

E: Package 'libgl1-mesa-glx' has no installation candidate

这是因为在Ubuntu 22.04 LTS及更高版本中,libgl1-mesa-glx这个包已经被libgl1-mesa-drilibgl1替代了。所以,我们需要换一套更通用、兼容各版本Ubuntu的依赖安装命令:

sudo apt update && sudo apt install -y \
    python3-pip \
    python3-venv \
    libx11-6 \
    libxcb1 \
    libxkbcommon-x11-0 \
    libgl1 \
    libgl1-mesa-dri \
    libqt6gui6 \
    libqt6core6 \
    libqt6widgets6

2.2.3、第三步: 验证 GUI 功能(可选)

为了确认GUI环境配置成功,可以安装一个小工具测试一下:

sudo apt install -y x11-apps
xeyes  # 运行后会在 Windows 桌面弹出一个眼睛跟随鼠标的窗口,说明 GUI 配置成功

如果能看到那双“眼睛”窗口,就证明从WSL到Windows的图形显示通道已经打通了。

2.2.4、安装Windows 端 VSCode 连接 WSL 开发

1.安装 Windows 版 VSCode

  • 从VSCode官网下载Windows版本并安装。注意,这里装的是Windows版,不是Ubuntu里的版本。

2.安装 中文语言包

  • 打开Windows端的VSCode,使用快捷键Ctrl+Shift+X打开扩展面板,搜索并安装“Chinese (Simplified) Language Pack for Visual Studio Code”(微软官方插件)。安装完成后重启VSCode,界面就会变成中文。

3.安装 WSL 插件

  • 同样在扩展面板中,搜索并安装“Remote - WSL”(微软官方插件)。这个插件是连接WSL开发环境的关键。

4.连接 WSL 环境

  • 安装完WSL插件后,点击VSCode左下角的「><」图标,选择「New WSL Window using Distro…」,然后选择你的Ubuntu发行版。
  • 此时,会弹出一个新的VSCode窗口,标题栏显示「WSL: Ubuntu」,这表示已经成功连接到WSL环境了。

Ubuntu安装PySide6开发桌面应用实践

接下来,点击左侧的“打开文件夹…”,或者按快捷键Ctrl+K Ctrl+O,在弹出的对话框中选择WSL里的项目目录(例如~/pyside6_demo)。

Ubuntu安装PySide6开发桌面应用实践

如果目录列表里没有,可以直接在路径输入框里输入~并回车,这会列出钱buntu下的主目录文件夹。然后在左侧边栏点击新建文件夹图标,创建一个项目目录。

Ubuntu安装PySide6开发桌面应用实践

进入项目目录后,新建一个main.py文件,输入下面的示例代码,然后点击编辑器右上方的“运行”按钮。

示例代码:

import sys
from PySide6.QtWidgets import QApplication, QMainWindow, QLabel, QPushButton, QVBoxLayout, QWidget

class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("WSL PySide6 测试")
        self.setFixedSize(400, 200)
        
        central = QWidget()
        self.setCentralWidget(central)
        layout = QVBoxLayout(central)
        
        self.label = QLabel("Hello WSL + PySide6!")
        layout.addWidget(self.label)
        
        btn = QPushButton("点击我")
        btn.clicked.connect(lambda: self.label.setText("Windows 显示 WSL 窗口!"))
        layout.addWidget(btn)

if __name__ == "__main__":
    app = QApplication(sys.argv)
    win = MainWindow()
    win.show()
    sys.exit(app.exec())

Ubuntu安装PySide6开发桌面应用实践

点击运行后,VSCode可能会提示缺少Python扩展。这时,点击弹窗中的“查找 Python 扩展 (F)”,或者手动按Ctrl+Shift+X打开扩展面板。

  • 在扩展面板搜索“Python”,找到微软官方的Python扩展。
  • 此时扩展按钮会显示为“在 WSL:Ubuntu 中安装”,点击它进行安装。
  • 安装完成后,VSCode会提示重新加载窗口,点击确认即可。

Ubuntu安装PySide6开发桌面应用实践

Ubuntu安装PySide6开发桌面应用实践

Ubuntu安装PySide6开发桌面应用实践

不过,VSCode默认使用的Python解释器可能是系统自带的。而我们之前已经把PySide6安装在了虚拟环境里。所以,需要手动切换解释器。使用快捷键Ctrl+Shift+P调出命令面板:

Ubuntu安装PySide6开发桌面应用实践

在命令面板中输入“Python: Select Interpreter”,然后选择我们之前创建好的虚拟环境中的解释器(路径通常类似~/pyside6_venv/bin/python)。

Ubuntu安装PySide6开发桌面应用实践

切换成功后,示例代码的依赖问题就解决了。再次点击运行,一个由WSL中的Python驱动、在Windows桌面显示的PySide6窗口就成功弹出了:

Ubuntu安装PySide6开发桌面应用实践

至此,整个开发环境的基础搭建流程就全部完成了,后续可以开始正式的桌面应用开发了。

三、Ubuntu桌面系统开发

至于在原生Ubuntu桌面系统上进行开发,流程会简单直接得多,这里就不展开细说了。时间关系,后续有机会再单独分享。

总结

以上便是在WSL2的Ubuntu环境中,从零开始搭建PySide6桌面应用开发环境的完整过程。希望这份踩坑记录能为大家提供一个清晰的参考。也欢迎大家持续关注本站,获取更多技术实践内容。


您可能感兴趣的文章:
  • 一句话理解pyside6的信号和槽机制
  • PySide6中QSS(Qt Style Sheet,类似CSS)支持的属性
  • Python+PySide6构建一个响应式视频剪辑工具
  • Python使用PySide6编写一个CSV文件浏览器
  • 浅谈pyside6 事件处理
  • pyside6中installEventFilter的使用
来源:https://www.jb51.net/python/362694e9v.htm
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

Ubuntu Apache怎样防止攻击
网络安全
Ubuntu Apache怎样防止攻击

要保护Ubuntu上的Apache服务器免受攻击,可以采取以下几种措施 想让你的Ubuntu Apache服务器固若金汤?其实没那么复杂,关键在于把几道基础防线扎牢。下面这套组合拳,能帮你有效抵御大部分常见的网络攻击。 防火墙配置:守好第一道门 防火墙是服务器的看门人,配置得当能挡掉大量不必要的麻烦

热心网友
04.23
ubuntu syslog怎么加密
网络安全
ubuntu syslog怎么加密

在Ubuntu系统中实现Syslog加密传输 在运维和安全管理中,syslog日志的明文传输一直是个潜在的风险点。好消息是,通过加密传输,我们可以有效保护日志数据在传输过程中的机密性和完整性。下面就来详细拆解一下,在Ubuntu系统上为syslog穿上“加密外衣”的几种主流方法。 1 使用Sysl

热心网友
04.23
Ubuntu VNC如何使用加密连接
网络安全
Ubuntu VNC如何使用加密连接

在Ubuntu上为VNC连接加上“安全锁”:SSH隧道加密指南 直接通过VNC远程连接Ubuntu桌面,虽然方便,但让数据在网络上“裸奔”总归让人不放心。别担心,有个既经典又可靠的方法能为这条通道加上一把“安全锁”——那就是利用SSH隧道对连接进行加密。下面就来详细拆解整个设置过程。 第一步:安装V

热心网友
04.23
Ubuntu VNC如何启用加密连接
网络安全
Ubuntu VNC如何启用加密连接

在Ubuntu上为VNC连接加上“安全锁”:启用加密的完整指南 直接暴露在公网上的VNC连接,无异于在“裸奔”。数据在传输过程中一旦被截获,后果不堪设想。好在,我们可以通过启用SSL TLS加密,为这条远程通道加上一把可靠的“安全锁”。下面,我们就来聊聊在Ubuntu系统上,如何为两种主流的VNC服

热心网友
04.23
Ubuntu Syslog如何实现日志加密
网络安全
Ubuntu Syslog如何实现日志加密

在Ubuntu系统中实现Syslog日志加密 在数据安全日益重要的今天,系统日志的明文存储和传输已经难以满足高安全级别的需求。好在,为Ubuntu系统中的Syslog日志加上“加密锁”并非难事,我们有好几种成熟、可靠的方案可以选择。下面就来详细聊聊这些方法。 方法一:使用rsyslog和GnuPG

热心网友
04.23

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

TripMate
AI
TripMate

TripMate是什么 规划一次完美的旅行,最磨人的往往是前期的信息海选和行程拼图。现在,一款名为TripMate的AI旅行助手,正试图把我们从这种繁琐中解放出来。简单来说,它是一个由人工智能驱动的个人旅行规划工具,核心目标就一个:让个性化的行程规划变得又快又省心。用户不必再在各种攻略网站间反复横跳

热心网友
04.23
Artwo
AI
Artwo

Artwo是什么 浏览器标签页多到能开火车,收藏夹杂乱得像毛线球——这大概是每个深度上网冲浪者的日常痛点。Artwo的出现,正是为了终结这种混乱。这款工具的核心,是将AI的智能与网页资源管理深度结合,帮你把散落各处的网页信息,整理成井井有条的知识库。它不仅仅是个高级书签管理器,更像是一个能理解你需求

热心网友
04.23
Best AI Jobs
AI
Best AI Jobs

Best AI Jobs是什么 当你琢磨着在人工智能领域找份新工作时,面对海量却不精准的招聘信息,是不是常常感到头疼?这时候,一个专业的垂直平台就显得尤为重要了。Best AI Jobs,正是为此而生。它是一个专注于人工智能领域的职业搜索引擎,核心使命就是帮用户在全球范围内精准定位AI相关的职位。无

热心网友
04.23
FreeAiKit
AI
FreeAiKit

FreeAIKit是什么 当你听到“AI工具套件”时,脑子里会浮现什么?复杂的代码、难懂的术语,还是昂贵的订阅费?FreeAIKit的出现,可以说彻底打破了这些刻板印象。这个由Easy With AI打造的综合平台,目标非常明确:让AI变得触手可及。它集成了图像生成、市场营销、生产力提升等一系列工具

热心网友
04.23
WPS Office
AI
WPS Office

WPS Office是什么 提到办公软件,很多人的第一反应可能是微软的Office套件。但今天,我们得好好聊聊另一个重量级选手——WPS Office。它出自中国的金山软件,是一款功能完整的免费办公解决方案。简单来说,它集成了文档编辑、表格处理、幻灯片制作以及PDF工具于一体,旨在为用户提供一个流畅

热心网友
04.23