PYQT + flask httpserver 服务器提供简单的MES服务

在这里插入图片描述
main.py

import sys
# 导入创建的文件模块
import test
import dcservice
from PyQt5.QtWidgets import QApplication, QMainWindow


if __name__ =='__main__':
    app = QApplication(sys.argv)
    MainWindow = QMainWindow()
    ui = test.Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())




test.py

# -*- coding: utf-8 -*-
import sys
import time

# Form implementation generated from reading ui file 'test.ui'
#
# Created by: PyQt5 UI code generator 5.15.9
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.



from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QFont
from PyQt5.QtWidgets import QTableWidgetItem, QHeaderView, QMessageBox, QMainWindow, QApplication
import dcservice

openflag = 1
class QMainWindow():
    """
    重写closeEvent方法
    """
    def closeEvent(self, event):
        result = QtWidgets.QMessageBox.question(self, "标题", "亲,你确定想关闭我?别后悔!!!'_'",
                                            QtWidgets.QMessageBox.Yes | QtWidgets.QMessageBox.No)
        if (result == QtWidgets.QMessageBox.Yes):
            event.accept()
        # 通知服务器的代码省略,这里不是重点...
        else:
            event.ignore()
class Ui_MainWindow(QMainWindow):
    def closeEvent(self, event):
        result = QMainWindow.QMessageBox.question(self, "标题", "亲,你确定想关闭我?别后悔!!!'_'",
                                                QMainWindow.QMessageBox.Yes | QMainWindow.QMessageBox.No)
        if (result == QMainWindow.QMessageBox.Yes):
            event.accept()
        # 通知服务器的代码省略,这里不是重点...
        else:
            event.ignore()
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(867, 700)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.tableWidget = QtWidgets.QTableWidget(self.centralwidget)
        self.tableWidget.setGeometry(QtCore.QRect(10, 10, 851, 581))
        self.tableWidget.setObjectName("tableWidget")
        self.tableWidget.setColumnCount(0)
        self.tableWidget.setRowCount(0)
        self.pushButton = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton.setGeometry(QtCore.QRect(560, 600, 271, 51))

        self.pushButton1 = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton1.setGeometry(QtCore.QRect(30, 600, 271, 51))


        font = QtGui.QFont()
        font.setFamily("Agency FB")
        font.setPointSize(18)
        self.pushButton.setFont(font)
        self.pushButton.setObjectName("pushButton")

        self.pushButton1.setFont(font)
        self.pushButton1.setObjectName("pushButton1")

        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 867, 23))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

        self.retranslateUi(MainWindow)
        MainWindow.destroyed.connect(self.close) # type: ignore
        self.pushButton.clicked.connect(self.CloseService) # type: ignore
        self.pushButton1.clicked.connect(self.OpenService)  # type: ignore
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
        self.InitTableWdiget()

    def InitTableWdiget(self):
        self.tableWidget.setRowCount(7)  # 设置表格行数
        self.tableWidget.setColumnCount(4)  # 设置表格列数
        self.tableWidget.verticalHeader().setVisible(False)
        self.tableWidget.horizontalHeader().setVisible(False)
        self.tableWidget.horizontalHeader().setSectionResizeMode(QtWidgets.QHeaderView.Stretch)
        # self.tableWidget.verticalHeader().setSectionResizeMode(QtWidgets.QHeaderView.Stretch)



        # 合并相同数据单元格
        # 合并第3列的第1-5行
        # (0表示第1行,2表示第3列,5表示跨越5<12345>1表示跨越1列)
        self.tableWidget.setSpan(2, 1, 1, 3)
        self.tableWidget.setSpan(3, 1, 1, 3)
        self.tableWidget.setSpan(4, 1, 1, 3)
        self.tableWidget.setSpan(5, 1, 1, 3)
        self.tableWidget.setSpan(6, 1, 1, 3)

        self.tableWidget.setRowHeight(0, 60)
        self.tableWidget.setRowHeight(1, 60)
        self.tableWidget.setRowHeight(2, 60)
        self.tableWidget.setRowHeight(3, 60)
        self.tableWidget.setRowHeight(4, 60)
        self.tableWidget.setRowHeight(5, 60)
        self.tableWidget.setRowHeight(6, 120)



        data = QTableWidgetItem(str('1状态'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        self.tableWidget.setItem(0, 0, data)

        data = QTableWidgetItem(str('2状态'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        self.tableWidget.setItem(1, 0, data)

        data = QTableWidgetItem(str('1产量'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        self.tableWidget.setItem(2, 0, data)

        data = QTableWidgetItem(str('2产量'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        self.tableWidget.setItem(3, 0, data)



        # data.setBackground(QtGui.QBrush(QtGui.QColor("yellow")))
        data = QTableWidgetItem(str('上传数据状态:'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        self.tableWidget.setItem(4, 0, data)

        data = QTableWidgetItem(str('服务状态:'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        self.tableWidget.setItem(5, 0, data)

        data = QTableWidgetItem(str('已启动'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 25))
        data.setForeground(QtGui.QBrush(QtGui.QColor("green")))  # 设置单元格文本颜色
        self.tableWidget.setItem(5, 1, data)

        data = QTableWidgetItem(str('已连接'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        data.setForeground(QtGui.QBrush(QtGui.QColor("green")))  # 设置单元格文本颜色
        self.tableWidget.setItem(0, 1, data)

        data = QTableWidgetItem(str('已断开'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setFont(QFont("Arial", 20))
        data.setForeground(QtGui.QBrush(QtGui.QColor("red")))  # 设置单元格文本颜色
        self.tableWidget.setItem(1, 1, data)

        self.tableWidget.setRowHeight(6, 200)
        data = QTableWidgetItem(str('异常日志:'))  # 转换后可插入表格
        data.setTextAlignment(Qt.AlignCenter)
        data.setForeground(QtGui.QBrush(QtGui.QColor("red")))  # 设置单元格文本颜色
        data.setFont(QFont("Arial", 20))
        data.setTextAlignment(Qt.AlignCenter)
        self.tableWidget.setItem(6, 0, data)

        dcservice._startService()

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.pushButton.setText(_translate("MainWindow", "关闭服务器"))
        self.pushButton1.setText(_translate("MainWindow", "打开服务器"))
    def closeEvent(self, event):
        pass
    def close(self):
        print('==============')
        pass
    def CloseService(self):
        global openflag
        if openflag == 1:
            openflag =0
            dcservice._stopService()
            data = QTableWidgetItem(str('已关闭'))  # 转换后可插入表格
            data.setTextAlignment(Qt.AlignCenter)
            data.setFont(QFont("Arial", 25))
            data.setForeground(QtGui.QBrush(QtGui.QColor("red")))  # 设置单元格文本颜色
            self.tableWidget.setItem(5, 1, data)
    def OpenService(self):
        global openflag
        if(openflag == 0):
            openflag = 1
            dcservice._startService()
            data = QTableWidgetItem(str('已启动'))  # 转换后可插入表格
            data.setTextAlignment(Qt.AlignCenter)
            data.setFont(QFont("Arial", 25))
            data.setForeground(QtGui.QBrush(QtGui.QColor("green")))  # 设置单元格文本颜色
            self.tableWidget.setItem(5, 1, data)
    def close(self):
        # self.CloseService()
        print('--------------------------------')
        print('00000000000000000000000000000000')
        sys.exit(-1)



dcservice.py

# -*- coding: UTF-8 -*-
# !/usr/bin/python
# @time     :2019/10/12 11:11
# @author   :Mo
# @function :service of flask
import ctypes
import inspect
import sys
import threading
import time

from flask import Flask, request, jsonify
from threading import Thread
import os

app = Flask(__name__)
app1 = Flask(__name__ + '1')
# mes交互需要的数据
################################################
# 接口名字
m_Cmd = 'getstatus'
# 工作台
m_table = 'Left'
# 机台设备号
m_EqNo = 'AE0001'
# 结果
m_result = 'true'
# 设备运行状态
m_process_state = 'Run'
# 错误消息
m_msg = '无'
# 产能
m_capicity = 1000
# 当前工序
m_currentProcess = ""
#设备名称
m_device_name=""
################################################


g_a = 100
g_b = 200
g_c = 300

t1=0
t2=0


@app.route('/dcservice', methods=["GET","POST"])
def calculate():
    global m_Cmd,m_table,m_EqNo,m_result ,m_process_state,m_msg,m_capicity,m_currentProcess
    if request.method == 'GET':
        params = params = request.args
        m_Cmd = params.get("Cmd", 0)
        if m_Cmd == 'getstatus':#获取设备机台状态接口
            return jsonify(content_type='application/json;charset=utf-8',
                           reason='success',
                           charset='utf-8',
                           status='200',
                           Cmd=m_Cmd,
                           EquNo=m_EqNo,
                           result=m_result,
                           Data=m_data,
                           Table = m_table,
                           msg = m_msg)
        elif m_Cmd == 'getcapicity':#获取产能
            return jsonify(content_type='application/json;charset=utf-8',
                           reason='success',
                           charset='utf-8',
                           status='200',
                           Cmd=m_Cmd,
                           EquNo=m_EqNo,
                           result=m_result,
                           Data=m_capicity,
                           Table=m_table,
                           msg=m_msg)
        else:
            return jsonify(
                result="true",
                Data="没找到对应指令",
                msg="")
    elif request.method == 'GET':
        pass
    else:
        return jsonify(
            result="true",
            Data="没找到对应指令",
            msg="")



@app1.route('/hometoservice', methods=["GET","POST"])
def calculate():
    global m_Cmd,m_table,m_EqNo,m_result ,m_process_state,m_msg,m_capicity,m_currentProcess,m_device_name
    if request.method == 'POST':
        params = params = request.args
        m_Cmd = params.get("Cmd", 0)
        if m_Cmd == 'set_ process':#设置当前工序
            m_currentProcess = params.get("current_ process", 0)
            return jsonify(
                           result="true",
                           Data="",
                           msg = "")
        elif m_Cmd == 'set_state':#设置设备状态
            m_process_state = params.get("current_state", 0)
            return jsonify(
                result="true",
                Data="",
                msg="")
        elif m_Cmd == 'Updata_baseInfo':#上传产能
            m_EqNo = params.get("EqNo", 0)
            m_capicity = params.get("capacity", 0)
            return jsonify(
                result="true",
                Data="",
                msg="")
    elif request.method == 'GET':
        params = params = request.args
        m_Cmd = params.get("Cmd", 0)
        if m_Cmd == 'Get_Lock_device':  # 请求机器锁定信号
            m_device_name = params.get("DC_wafer_bonding_machine", 0)
            return jsonify(
                result="true",
                Data="",
                msg="")
        elif m_Cmd == 'Get_Sheet':  # 请求配方
            m_device_name = params.get("DC_wafer_bonding_machine", 0)
            return jsonify(
                result="true",
                Config= "GJ_NAME",
                Data="",
                msg="")
        else:
            return jsonify(
                result="true",
                Data="没找到对应指令",
                msg="")
    else:
        return jsonify(
            result="true",
            Data="没找到对应指令",
            msg="")

def _startService():
    global t1
    global t2
    t1 = threading.Thread(target=lambda: app1.run(host='0.0.0.0', threaded=True,debug=False, port=5002))
    t2 = threading.Thread(target=lambda: app.run(host='0.0.0.0', threaded=True, debug=False, port=5001))
    t1.start()
    t2.start()
def _stopService():
    global t1
    global t2
    stop_thread(t1)
    stop_thread(t2)


def _async_raise(tid, exctype):
    if not inspect.isclass(exctype):
        raise TypeError("Only types can be raised (not instances)")
    res = ctypes.pythonapi.PyThreadState_SetAsyncExc(ctypes.c_long(tid), ctypes.py_object(exctype))
    if res == 0:
        raise ValueError("invalid thread id")
    elif res != 1:
        ctypes.pythonapi.PyThreadState_SetAsyncExc(tid, None)
        raise SystemError("PyThreadState_SetAsyncExc failed")


def stop_thread(thread):
    _async_raise(thread.ident, SystemExit)


if __name__ == '__main__':
    print('start')
    _startService()

相关推荐

  1. 租用服务器提供服务

    2024-06-08 12:22:01       6 阅读
  2. 简单WEB服务器

    2024-06-08 12:22:01       38 阅读
  3. 简单Udp服务器

    2024-06-08 12:22:01       32 阅读
  4. 一个简单websocket服务

    2024-06-08 12:22:01       9 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-08 12:22:01       17 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-08 12:22:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-08 12:22:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-08 12:22:01       18 阅读

热门阅读

  1. Vue Router——hash模式和 history模式

    2024-06-08 12:22:01       10 阅读
  2. Elasticsearch 认证模拟题 - 10

    2024-06-08 12:22:01       10 阅读
  3. TCP和udp能使用同一个端口通讯吗

    2024-06-08 12:22:01       8 阅读
  4. 设计模式总结

    2024-06-08 12:22:01       6 阅读
  5. UVa1116/LA2429 Puzzle

    2024-06-08 12:22:01       5 阅读
  6. #07 使用Stable Diffusion生成高质量图片的技巧

    2024-06-08 12:22:01       8 阅读
  7. HTTP参数污染漏洞

    2024-06-08 12:22:01       8 阅读
  8. 速盾:图片cdn托管

    2024-06-08 12:22:01       9 阅读