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

news2024/11/15 20:00:31

在这里插入图片描述
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()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1800995.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

苹果 2023 年威胁研究的 8 个要点

苹果公司最近发布了其对 2023 年遇到的网络安全威胁的调查结果和观察。 该研究揭示了有趣的数据点&#xff0c;并展示了威胁形势是如何演变的。 1. 攻击者越来越多地瞄准消费者数据 仅 2023 年前八个月&#xff0c;就有超过 3.6 亿人成为企业数据泄露的受害者&#xff0c;这…

Qt下调用Snap7库与西门子PLC通信

文章目录 前言一、Snap7源码下载二、Snap7的dll常用函数功能介绍三、Snap7Lib.pri模块的封装四、下载链接总结 前言 本文主要讲述了在Qt下调用Snap7库与西门子PLC进行通信&#xff0c;在这里将Snap7的源码与动态库整合在一起封装了一个自己的Snap7Lib.pri子模块&#xff0c;方…

使用Gitblit软件开启git服务器

文章目录 使用Gitblit软件开启git服务器&#xff0c;供局域网其他电脑当做git仓库服务1. java依赖环境安装2. Mac系统操作2.1 下载Gitblit、配置参数2.2 启动服务2.3 终止服务&#xff1a;停止脚本即可 3. window系统操作3.1 下载Gitblit、配置参数3.2 启动服务3.3 终止服务&am…

科技云报道:走出“实验室”,GenAI迎来关键拐点

科技云报道原创。 对传统产业来说&#xff0c;GenAI是一场“哥白尼式的革命”&#xff0c;它改变了传统的业务模式&#xff0c;开启了人类与AI合作的新纪元。基于AI助手和大语言模型&#xff0c;企业能够实现智能运营的目标。 如果说&#xff0c;2022年是AI大模型元年&#x…

mysql工具----dbForgeStudio2020

dbForgeStudio2020&#xff0c;除了基本的操作外&#xff0c;还具有可调试mysql存储过程的功能&#xff0c;是一个不可夺得的mysql软件工具。 本文的软件将简单介绍软件的安装方式&#xff0c;仅供学习交流&#xff0c;不可做它用。 1.安装软件&#xff0c;安装后&#xff0c…

Chrome DevTools解密:成为前端调试大师的终极攻略

Chrome DevTools是一套内置于Google Chrome浏览器中的开发者工具&#xff0c;它允许开发者对网页进行调试、分析和优化。本文将全面介绍DevTools的功能、使用方法以及注意事项&#xff0c;帮助开发者更好地利用这些工具来提升开发效率和网页性能。 一、简介 1. DevTools是什么…

RabbitMQ-工作模式(Publish模式Routing模式)

文章目录 发布/订阅&#xff08;Publish/Subscribe&#xff09;交换机临时队列绑定总体代码示例 路由&#xff08;Routing&#xff09;绑定直连交换机多重绑定发送日志订阅总体代码示例 更多相关内容可查看 发布/订阅&#xff08;Publish/Subscribe&#xff09; 构建一个简单的…

Playwright框架入门

自从2023年底playwright框架火起来之后,很多小伙伴咨询我们这个框架,甚至问我们什么时候出这个课程. 这步这个课程在我们千呼万唤中出来了.具体的课程大纲和试听可以联系下方二维码获取. 今天给大家分享一下playwright的安装和一些常用API,为后续的学习做好准备工作. Playwrig…

批量重命名大解放!自定义取文本左侧长度,轻松实现文件名焕新之旅!

文件管理是我们日常工作和生活中不可或缺的一部分。然而&#xff0c;面对成千上万的文件&#xff0c;手动重命名无疑是一项繁琐且耗时的任务。今天&#xff0c;我们为您推荐一款高效便捷的批量文件重命名工具——文件批量改名高手&#xff0c;让您轻松实现取文本左的长度来进行…

【PythonCode】力扣Leetcode21~25题Python版

【PythonCode】力扣Leetcode21~25题Python版 前言 力扣Leetcode是一个集学习、刷题、竞赛等功能于一体的编程学习平台&#xff0c;很多计算机相关专业的学生、编程自学者、IT从业者在上面学习和刷题。 在Leetcode上刷题&#xff0c;可以选择各种主流的编程语言&#xff0c;如C…

【会议征稿,IEEE出版】EEI 2024,6月28-30

第六届电子工程与信息学国际学术会议&#xff08;EEI 2024&#xff09;将于2024年6月28日至6月30日在中国重庆召开。EEI 2024将围绕“电子工程”、“信息学”与“计算机科学”等相关最新研究领域 &#xff0c;为来自国内外高等院校、科学研究所、企事业单位的专家、教授、学者、…

海康威视综合安防管理平台 多处 FastJson反序列化RCE漏洞复现

0x01 产品简介 海康威视综合安防管理平台是一套“集成化”、“智能化”的平台,通过接入视频监控、一卡通、停车场、报警检测等系统的设备。海康威视集成化综合管理软件平台,可以对接入的视频监控点集中管理,实现统一部署、统一配置、统一管理和统一调度。 0x02 漏洞概述 由于…

javacv ffmpeg使用笔记 (补充中...)

javacv ffmpeg使用笔记 一、maven依赖二、示例代码1. 获取视频时长 三、小技巧 一、maven依赖 使用javacv ffmpeg并指定classifier之后&#xff0c;就不需要额外安装ffmpeg软件&#xff08;jar包中已经内置&#xff09;了。 全量依赖包&#xff08;不推荐&#xff09;安装包总大…

Docker 管理 | 代理配置、内网共享和 Harbor 部署

唠唠闲话 在现代软件开发和运维中&#xff0c;容器技术已经成为构建、部署和管理应用程序的标准工具。然而&#xff0c;在实际操作中&#xff0c;我们常常需要面对一些常见的挑战&#xff0c;如容器访问外部资源的代理配置、内网环境下的镜像共享以及企业级镜像管理。 本教程…

Transformer动画讲解:注意力计算Q、K、V

暑期实习基本结束了&#xff0c;校招即将开启。 不同以往的是&#xff0c;当前职场环境已不再是那个双向奔赴时代了。求职者在变多&#xff0c;HC 在变少&#xff0c;岗位要求还更高了。提前准备才是完全之策。 最近&#xff0c;我们又陆续整理了很多大厂的面试题&#xff0c…

自动化Reddit图片收集:Python爬虫技巧

引言 Reddit&#xff0c;作为一个全球性的社交平台&#xff0c;拥有海量的用户生成内容&#xff0c;其中包括大量的图片资源。对于数据科学家、市场研究人员或任何需要大量图片资源的人来说&#xff0c;自动化地从Reddit收集图片是一个极具价值的技能。本文将详细介绍如何使用…

GCB | 全球草地和森林土壤呼吸对降水量变化的不对称响应

全球变化导致地球水文循环的强化放大了降水的年际变化&#xff0c;这将显著影响陆地碳&#xff08;C&#xff09;循环。然而&#xff0c;在极端降水变化情况下&#xff0c;先前观测到的土壤呼吸&#xff08;Rs&#xff09;和降水之间的关系是否仍然适用&#xff0c;目前仍不清楚…

thinkphp6.0版本下子查询sql处理

目录 一&#xff1a;背景 二&#xff1a;查询实例 三&#xff1a;总结 一&#xff1a;背景 我们在实际业务的开发过程中&#xff0c;经常会碰到这样的场景&#xff0c;查询某些部门的客户信息&#xff0c;查询下过订单的客户信息。这里查询客户信息实际上就用到了子查询&…

PS的stable diffusion插件安装指南

PS的stable diffusion插件安装指南 1.首先要安装stable diffusion&#xff0c;具体安装方法&#xff0c;参考https://blog.csdn.net/sheji888/article/details/139196688 stable diffusion要求要启用API功能 2.安装ps2023以上版本&#xff0c;低于这个版本不能使用stable diff…

TCP攻击是怎么实现的,如何防御?

TCP&#xff08;Transmission Control Protocol&#xff09;是互联网协议族中的重要组成部分&#xff0c;用于在不可靠的网络上提供可靠的数据传输服务。然而&#xff0c;TCP协议的一些特性也使其成为攻击者的目标&#xff0c;尤其是DDoS&#xff08;Distributed Denial of Ser…