PyQt6内嵌http.server Web 和Flask Web服务器方法详解

PyQt6 可以内嵌一个简单的 Web 服务器。虽然 PyQt6 本身不提供直接的 Web 服务器功能,但可以结合 Python 的标准库(如 http.server)或其他 Web 框架(如 Flask、FastAPI 等)来实现。

示例:使用 http.server内嵌 Web 服务器

以下是一个简单的例子,展示如何在 PyQt6 应用中内嵌一个基本的 Web 服务器:

import sys

from PyQt6.QtWidgets import QApplication, QMainWindow, QTextEdit

from PyQt6.QtCore import QThread, pyqtSignal

from http.server import BaseHTTPRequestHandler, HTTPServer

class SimpleHTTPRequestHandler(BaseHTTPRequestHandler):

def do_GET(self):

self.send_response(200)

self.send_header('Content-type', 'text/html')

self.end_headers()

self.wfile.write(b"Hello from PyQt6 Web Server!")

class WebServerThread(QThread):

def run(self):

server_address = ('', 8000)

httpd = HTTPServer(server_address, SimpleHTTPRequestHandler)

print("Web server running on port 8000...")

httpd.serve_forever()

class MainWindow(QMainWindow):

def init(self):

super().init()

self.setWindowTitle("PyQt6 Web Server Example")

self.text_edit = QTextEdit(self)

self.setCentralWidget(self.text_edit)

self.text_edit.setText("Web server is running...")

self.webserver_thread = WebServerThread()

self.webserver_thread.start()

if name == "main":

app = QApplication(sys.argv)

window = MainWindow()

window.show()

sys.exit(app.exec())

关键点:

  1. SimpleHTTPRequestHandler:这是一个简单的 HTTP 请求处理器,用于处理 GET 请求并返回响应。

  2. WebServerThread:这是一个 QThread 子类,用于在后台运行 Web 服务器,避免阻塞主线程。

  3. MainWindow:这是 PyQt6 的主窗口,启动时会在后台运行 Web 服务器。

运行效果:

  • 运行程序后,Web 服务器会在 http://localhost:8000上启动。

  • 访问该地址时,会看到 "Hello from PyQt6 Web Server!" 的响应。

  • PyQt6 应用的主窗口会显示 "Web server is running..."。

注意事项:

  • 这种方法适合简单的场景。如果需要更复杂的功能(如路由、模板渲染等),建议使用 Flask 或 FastAPI 等框架。

Pyqt6内嵌Flask框架完整的示例代码:

from flask import Flask, render_template_string

app = Flask(name)

@app.route('/')

def index():

return render_template_string('''

<h1>Hello, Flask in PyQt6!</h1>

<p>This is a Flask application embedded in PyQt6.</p>

''')

PyQt6 主程序 (main.py)

import sys

from PyQt6.QtWidgets import QApplication, QMainWindow

from PyQt6.QtWebEngineWidgets import QWebEngineView

from PyQt6.QtCore import QUrl

import threading

import time

from werkzeug.serving import make_server

from flask_app import app

class FlaskThread(threading.Thread):

def init(self, app):

threading.Thread.init(self)

self.server = make_server('127.0.0.1', 5000, app)

self.ctx = app.app_context()

self.ctx.push()

def run(self):

self.server.serve_forever()

def shutdown(self):

self.server.shutdown()

class MainWindow(QMainWindow):

def init(self):

super().init()

self.setWindowTitle("PyQt6 with Flask")

self.setGeometry(100, 100, 800, 600)

self.browser = QWebEngineView()

self.setCentralWidget(self.browser)

self.start_flask()

def start_flask(self):

self.flask_thread = FlaskThread(app)

self.flask_thread.start()

time.sleep(1)

self.browser.setUrl(QUrl("http://127.0.0.1:5000"))

def closeEvent(self, event):

self.flask_thread.shutdown()

event.accept()

if name == 'main':

qt_app = QApplication(sys.argv)

window = MainWindow()

window.show()

sys.exit(qt_app.exec())

打包命令

pyinstaller --onefile --windowed --add-data "flask_app.py;." main.py

通过以上步骤,你可以将 PyQt6 内嵌 Flask 的应用打包成一个独立的可执行文件,并在没有 Python 环境的电脑上运行。

相关推荐
SelectDB12 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
荣码20 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
金銀銅鐵1 天前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li1 天前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸2 天前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学2 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
喵个咪2 天前
Go-Wind HTTP 服务器从入门到精通
后端·http·go
花酒锄作田2 天前
Pydantic校验配置文件
python
hboot2 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
ZhengEnCi3 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化