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()
相关推荐
Rhys..13 分钟前
python自动化中(包括UI自动化和API自动化)env的作用和使用
python·ui·自动化
我的xiaodoujiao33 分钟前
从 0 到 1 搭建完整 Python 语言 Web UI自动化测试学习系列 17--测试框架Pytest基础 1--介绍使用
python·学习·测试工具·pytest
Bellafu66636 分钟前
selenium对每种前端控件的操作,python举例
前端·python·selenium
将车2441 小时前
自动化测试脚本环境搭建
python·测试工具·自动化
海祁1 小时前
【python学习】文件操作
python·学习
jianqiang.xue1 小时前
单片机图形化编程:课程目录介绍 总纲
c++·人工智能·python·单片机·物联网·青少年编程·arduino
Siren_dream1 小时前
python进阶_Day8
开发语言·python
姬嘉晗-19期-河北工职大1 小时前
HCL设备启动失败
python·终端·anaconda·解释器
淬炼之火1 小时前
基于pycharm和anaconda的yolo简单部署测试
python·深度学习·yolo·pycharm·ultralytics
麦麦大数据2 小时前
F024 CNN+vue+flask电影推荐系统vue+python+mysql+CNN实现
vue.js·python·cnn·flask·推荐算法