Python和PySide6实现分别实现tcp通信。

通用界面代码:ui.py

python 复制代码
#tcp通讯/ui.py
from PySide6.QtWidgets import *

class Window(QWidget):

    def __init__(self):
        super().__init__()
        self.init_ui()
    def init_ui(self):
        self.plainTextEdit = QPlainTextEdit(self)
        self.plainTextEdit.setGeometry(20,20,200,200)

    def add_str(self,meg:str):
        self.plainTextEdit.appendHtml(f"<p>{meg}</p>")
        scrollbar = self.plainTextEdit.verticalScrollBar()
        if scrollbar.isVisible():
            scrollbar.setSliderPosition(scrollbar.maximum())

Python实现TCP 服务端代码:

python 复制代码
import socket
import sys
import threading
from PySide6.QtWidgets import *
from ui import Window


class TCP_Server_Python:
    def __init__(self):
        self.ui = Window()
        self.ui.show()
        self.socket_thread = threading.Thread(target=self.do_job, daemon=True)
        self.socket_thread.start()
    def do_job(self):
        with socket.socket() as server:
            server.bind(('0.0.0.0',6002))
            server.listen(10)
            print("服务器已经启动。。。。。。。")
            conn, _server = server.accept()
            while True:
                print("已经连接")
                data = b''
                try:
                    data = conn.recv(1024)
                except Exception as e:
                    pass
                else:
                    if data == b'\x01':
                        print("关闭")
                        break
                    self.ui.add_str(data)





if __name__ == '__main__':

    # 创建一个应用程序实例
    app = QApplication(sys.argv)

    # 创建一个顶层窗口
    window = TCP_Server_Python()


    # 进入应用程序的主循环,等待事件处理
    sys.exit(app.exec())

Pyside6中QTcpSocket实现代码:

python 复制代码
import sys
from PySide6.QtWidgets import *
from PySide6.QtCore import *
from ui import Window
from PySide6.QtNetwork import QTcpServer,QHostAddress,QTcpSocket

class Qt_Tcp_Server:
    def __init__(self):
        self.ui = Window()
        self.ui.show()

        self.tcp_servet = QTcpServer()
        self.tcp_servet.listen(QHostAddress.SpecialAddress.Any,port=6002)
        self.ui.add_str("...服务器已经启动")
        self.tcp_servet.newConnection.connect(self.on_new_connection)#连接信号

    @Slot()
    def on_new_connection(self):
        '''新的连接槽函数'''
        second_socket:QTcpSocket = self.tcp_servet.nextPendingConnection()
        client_ip = second_socket.peerAddress().toString().split(":")[-1]
        client_port = second_socket.peerPort()
        msg = f"新连接的客户端ip地址为:{client_ip},端口号:{client_port}"
        self.ui.add_str(msg)
        second_socket.readyRead.connect(lambda :self.on_second_socket_ready_read(second_socket))
    @Slot()
    def on_second_socket_ready_read(self,socket:QTcpSocket):
        '''当有数据时触发该函数'''
        # data = socket.readAll() #全部读取
        #读取一行
        while socket.bytesAvailable()>0:
            line_byte = socket.readLine()
            self.ui.add_str(line_byte)


if __name__ == '__main__':

    app = QApplication(sys.argv)

    window = Qt_Tcp_Server()

    sys.exit(app.exec())
相关推荐
兵慌码乱8 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
luckdewei11 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化
python
aqi0017 小时前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn18 小时前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
金銀銅鐵1 天前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup112 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi002 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵2 天前
用 Python 实现 Take-Away 游戏
python·游戏