python udp双向通信

复制代码
import json
import socket
import threading
import logging

thislist = []
thisneednum = {}

class ChatUdpMain:
   def __init__(self):

      #其他原有逻辑 begin

      #其他原有逻辑 end

      #  1.创建socket套接字   收
      self.udp_socket_receive = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)  # AF_INET表示使用ipv4,默认不变,SOCK_DGRAM表示使用UDP通信协议
      #  2.绑定端口port  收
      local_addr_receive = ("127.0.0.1", 45678)  # 默认本机任何ip ,指定端口号45678,用于接收数据
      self.udp_socket_receive.bind(local_addr_receive)  # 绑定端口

      #  1.创建socket套接字   发
      self.udp_socket_send = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)  # AF_INET表示使用ipv4,默认不变,SOCK_DGRAM表示使用UDP通信协议
      #  2.绑定端口port  发
      local_addr_send = ("127.0.0.1", 45671)  # 默认本机任何ip,初始化使用,实际45671没有用
      self.udp_socket_send.bind(local_addr_send)  # 绑定端口
      self.start()

      self.thislist = thislist
      self.thisneednum = thisneednum

   def close(self):
      try:
         self.udp_socket_send.close()
         self.udp_socket_receive.close()
      except Exception as e:
          logging.info(e)

   def send(self, val: str):
      try:
         data = str.encode(str(val))
         self.udp_socket_send.sendto(data, ("127.0.0.1", 45679))  # 默认本机任何ip ,45679是发数据的端口
      except Exception as e:
          logging.info(e)

   # 开启线程
   def start(self):
      # 启动新线程接收数据
      threading.Thread(target=self._recv, name='recv').start()

   #接收qt发来的实时数据
   def _recv(self):
      while 1:
         try:
            self.recevalue = self.udp_socket_receive.recv(5000)
            print("收到数据  ")
            print(self.recevalue)
            try:
               i = 1
               for k, v in json.loads(self.recevalue).items():
                  if k in self.thislist:
                     self.thisneednum[i] = v
                     i += 1
               print("数据解析成功")

               self.jisuan(self.thisneednum)
            except ValueError:
               print("ValueError")


         except Exception as e:
            logging.info(e)

   def jisuan(self, d: dict):
      for i in self.thisneednum:
         print(self.thisneednum[i])

      #这里就是计算

      #得到结果
      # JSON 字符串
      json_string = '{"Type": "PCA","name": "Kyrie", "age": 31}'

      # 解析 JSON 字符串
      self.data = json.loads(json_string)
      self.data = json.dumps(self.data)
      # 给qt发结果
      self.send(self.data)

      #self.close()

def needcs():
    with open("config-PCA.ini", "r") as f:
        str = f.read()
        strlist = str.split(',')
    for item in strlist:
        thislist.append(item)

#主函数
def main():
    needcs()
    chatUdp = ChatUdpMain()

if __name__ == '__main__':
    main()
相关推荐
前端摸鱼匠8 分钟前
YOLOv11与OpenCV 联动实战:读取摄像头实时视频流并用 YOLOv11 进行检测(三)
人工智能·python·opencv·yolo·目标检测·计算机视觉·目标跟踪
Pyeako22 分钟前
PyQt5 + PaddleOCR实战:打造桌面级实时文字识别工具
开发语言·人工智能·python·qt·paddleocr·pyqt5
喝凉白开都长肉的大胖子1 小时前
在 Matplotlib 中fontweight一般怎么设置
python·matplotlib
HAPPY酷2 小时前
Python高级架构师之路——从原理到实战
java·python·算法
Thomas.Sir3 小时前
第十三章:RAG知识库开发之【GraphRAG 从基础到实战】
python·ai·rag·graphrag
一个处女座的程序猿O(∩_∩)O3 小时前
Python基础知识大全:从零开始掌握Python核心语法
开发语言·python
小陈工3 小时前
Python Web开发入门(十一):RESTful API设计原则与最佳实践——让你的API既优雅又好用
开发语言·前端·人工智能·后端·python·安全·restful
deephub4 小时前
ADK 多智能体编排:SequentialAgent、ParallelAgent 与 LoopAgent 解析
人工智能·python·大语言模型·agent
FL16238631294 小时前
基于yolov26+pyqt5的混凝土墙面缺陷检测系统python源码+pytorch模型+评估指标曲线+精美GUI界面
python·qt·yolo
cxr8285 小时前
GPU 加速声场求解器 CUDA Kernel 实现细节 —— 高频超声传播仿真并行计算引擎
人工智能·python·目标跟踪