友善串口工具接收数据随机换行_使用Python3+PyQT5+Pyserial 实现简单的串口工具方法...

练手项目,先上图

91f6fbf027099692764292ecde08238e.png

先实现一个简单的串口工具,为之后的上位机做准备

代码如下:

pyserial_demo.py

import sys
import serial
import serial.tools.list_ports
from PyQt5 import QtWidgets
from PyQt5.QtWidgets import QMessageBox
from PyQt5.QtCore import QTimer
from ui_demo_1 import Ui_Formclass Pyqt5_Serial(QtWidgets.QWidget, Ui_Form):def __init__(self):super(Pyqt5_Serial, self).__init__()self.setupUi(self)self.init()self.setWindowTitle("串口小助手")self.ser = serial.Serial()self.port_check()# 接收数据和发送数据数目置零self.data_num_received = 0self.lineEdit.setText(str(self.data_num_received))self.data_num_sended = 0self.lineEdit_2.setText(str(self.data_num_sended))def init(self):# 串口检测按钮self.s1__box_1.clicked.connect(self.port_check)# 串口信息显示self.s1__box_2.currentTextChanged.connect(self.port_imf)# 打开串口按钮self.open_button.clicked.connect(self.port_open)# 关闭串口按钮self.close_button.clicked.connect(self.port_close)# 发送数据按钮self.s3__send_button.clicked.connect(self.data_send)# 定时发送数据self.timer_send = QTimer()self.timer_send.timeout.connect(self.data_send)self.timer_send_cb.stateChanged.connect(self.data_send_timer)# 定时器接收数据self.timer = QTimer(self)self.timer.timeout.connect(self.data_receive)# 清除发送窗口self.s3__clear_button.clicked.connect(self.send_data_clear)# 清除接收窗口self.s2__clear_button.clicked.connect(self.receive_data_clear)# 串口检测def port_check(self):# 检测所有存在的串口,将信息存储在字典中self.Com_Dict = {}port_list = list(serial.tools.list_ports.comports())self.s1__box_2.clear()for port in port_list:self.Com_Dict["%s" % port[0]] = "%s" % port[1]self.s1__box_2.addItem(port[0])if len(self.Com_Dict) == 0:self.state_label.setText(" 无串口")# 串口信息def port_imf(self):# 显示选定的串口的详细信息imf_s = self.s1__box_2.currentText()if imf_s != "":self.state_label.setText(self.Com_Dict[self.s1__box_2.currentText()])# 打开串口def port_open(self):self.ser.port = self.s1__box_2.currentText()self.ser.baudrate = int(self.s1__box_3.currentText())self.ser.bytesize = int(self.s1__box_4.currentText())self.ser.stopbits = int(self.s1__box_6.currentText())self.ser.parity = self.s1__box_5.currentText()try:self.ser.open()except:QMessageBox.critical(self, "Port Error", "此串口不能被打开!")return None# 打开串口接收定时器,周期为2msself.timer.start(2)if self.ser.isOpen():self.open_button.setEnabled(False)self.close_button.setEnabled(True)self.formGroupBox1.setTitle("串口状态(已开启)")# 关闭串口def port_close(self):self.timer.stop()self.timer_send.stop()try:self.ser.close()except:passself.open_button.setEnabled(True)self.close_button.setEnabled(False)self.lineEdit_3.setEnabled(True)# 接收数据和发送数据数目置零self.data_num_received = 0self.lineEdit.setText(str(self.data_num_received))self.data_num_sended = 0self.lineEdit_2.setText(str(self.data_num_sended))self.formGroupBox1.setTitle("串口状态(已关闭)")# 发送数据def data_send(self):if self.ser.isOpen():input_s = self.s3__send_text.toPlainText()if input_s != "":# 非空字符串if self.hex_send.isChecked():# hex发送input_s = input_s.strip()send_list = []while input_s != '':try:num = int(input_s[0:2], 16)except ValueError:QMessageBox.critical(self, 'wrong data', '请输入十六进制数据,以空格分开!')return Noneinput_s = input_s[2:].strip()send_list.append(num)input_s = bytes(send_list)else:# ascii发送input_s = (input_s + 'rn').encode('utf-8')num = self.ser.write(input_s)self.data_num_sended += numself.lineEdit_2.setText(str(self.data_num_sended))else:pass# 接收数据def data_receive(self):try:num = self.ser.inWaiting()except:self.port_close()return Noneif num > 0:data = self.ser.read(num)num = len(data)# hex显示if self.hex_receive.checkState():out_s = ''for i in range(0, len(data)):out_s = out_s + '{:02X}'.format(data[i]) + ' 'self.s2__receive_text.insertPlainText(out_s)else:# 串口接收到的字符串为b'123',要转化成unicode字符串才能输出到窗口中去self.s2__receive_text.insertPlainText(data.decode('iso-8859-1'))# 统计接收字符的数量self.data_num_received += numself.lineEdit.setText(str(self.data_num_received))# 获取到text光标textCursor = self.s2__receive_text.textCursor()# 滚动到底部textCursor.movePosition(textCursor.End)# 设置光标到text中去self.s2__receive_text.setTextCursor(textCursor)else:pass# 定时发送数据def data_send_timer(self):if self.timer_send_cb.isChecked():self.timer_send.start(int(self.lineEdit_3.text()))self.lineEdit_3.setEnabled(False)else:self.timer_send.stop()self.lineEdit_3.setEnabled(True)# 清除显示def send_data_clear(self):self.s3__send_text.setText("")def receive_data_clear(self):self.s2__receive_text.setText("")if __name__ == '__main__':app = QtWidgets.QApplication(sys.argv)myshow = Pyqt5_Serial()myshow.show()sys.exit(app.exec_())

ui_demo_1.py

from PyQt5 import QtCore, QtGui, QtWidgetsclass Ui_Form(object):def setupUi(self, Form):Form.setObjectName("Form")Form.resize(707, 458)self.formGroupBox = QtWidgets.QGroupBox(Form)self.formGroupBox.setGeometry(QtCore.QRect(20, 20, 167, 301))self.formGroupBox.setObjectName("formGroupBox")self.formLayout = QtWidgets.QFormLayout(self.formGroupBox)self.formLayout.setContentsMargins(10, 10, 10, 10)self.formLayout.setSpacing(10)self.formLayout.setObjectName("formLayout")self.s1__lb_1 = QtWidgets.QLabel(self.formGroupBox)self.s1__lb_1.setObjectName("s1__lb_1")self.formLayout.setWidget(0, QtWidgets.QFormLayout.LabelRole, self.s1__lb_1)self.s1__box_1 = QtWidgets.QPushButton(self.formGroupBox)self.s1__box_1.setAutoRepeatInterval(100)self.s1__box_1.setDefault(True)self.s1__box_1.setObjectName("s1__box_1")self.formLayout.setWidget(0, QtWidgets.QFormLayout.FieldRole, self.s1__box_1)self.s1__lb_2 = QtWidgets.QLabel(self.formGroupBox)self.s1__lb_2.setObjectName("s1__lb_2")self.formLayout.setWidget(1, QtWidgets.QFormLayout.LabelRole, self.s1__lb_2)self.s1__box_2 = QtWidgets.QComboBox(self.formGroupBox)self.s1__box_2.setObjectName("s1__box_2")self.formLayout.setWidget(1, QtWidgets.QFormLayout.FieldRole, self.s1__box_2)self.s1__lb_3 = QtWidgets.QLabel(self.formGroupBox)self.s1__lb_3.setObjectName("s1__lb_3")self.formLayout.setWidget(3, QtWidgets.QFormLayout.LabelRole, self.s1__lb_3)self.s1__box_3 = QtWidgets.QComboBox(self.formGroupBox)self.s1__box_3.setObjectName("s1__box_3")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.s1__box_3.addItem("")self.formLayout.setWidget(3, QtWidgets.QFormLayout.FieldRole, self.s1__box_3)self.s1__lb_4 = QtWidgets.QLabel(self.formGroupBox)self.s1__lb_4.setObjectName("s1__lb_4")self.formLayout.setWidget(4, QtWidgets.QFormLayout.LabelRole, self.s1__lb_4)self.s1__box_4 = QtWidgets.QComboBox(self.formGroupBox)self.s1__box_4.setObjectName("s1__box_4")self.s1__box_4.addItem("")self.s1__box_4.addItem("")self.s1__box_4.addItem("")self.s1__box_4.addItem("")self.formLayout.setWidget(4, QtWidgets.QFormLayout.FieldRole, self.s1__box_4)self.s1__lb_5 = QtWidgets.QLabel(self.formGroupBox)self.s1__lb_5.setObjectName("s1__lb_5")self.formLayout.setWidget(5, QtWidgets.QFormLayout.LabelRole, self.s1__lb_5)self.s1__box_5 = QtWidgets.QComboBox(self.formGroupBox)self.s1__box_5.setObjectName("s1__box_5")self.s1__box_5.addItem("")self.formLayout.setWidget(5, QtWidgets.QFormLayout.FieldRole, self.s1__box_5)self.open_button = QtWidgets.QPushButton(self.formGroupBox)self.open_button.setObjectName("open_button")self.formLayout.setWidget(7, QtWidgets.QFormLayout.SpanningRole, self.open_button)self.close_button = QtWidgets.QPushButton(self.formGroupBox)self.close_button.setObjectName("close_button")self.formLayout.setWidget(8, QtWidgets.QFormLayout.SpanningRole, self.close_button)self.s1__lb_6 = QtWidgets.QLabel(self.formGroupBox)self.s1__lb_6.setObjectName("s1__lb_6")self.formLayout.setWidget(6, QtWidgets.QFormLayout.LabelRole, self.s1__lb_6)self.s1__box_6 = QtWidgets.QComboBox(self.formGroupBox)self.s1__box_6.setObjectName("s1__box_6")self.s1__box_6.addItem("")self.formLayout.setWidget(6, QtWidgets.QFormLayout.FieldRole, self.s1__box_6)self.state_label = QtWidgets.QLabel(self.formGroupBox)self.state_label.setText("")self.state_label.setTextFormat(QtCore.Qt.AutoText)self.state_label.setScaledContents(True)self.state_label.setAlignment(QtCore.Qt.AlignRight|QtCore.Qt.AlignTrailing|QtCore.Qt.AlignVCenter)self.state_label.setObjectName("state_label")self.formLayout.setWidget(2, QtWidgets.QFormLayout.SpanningRole, self.state_label)self.verticalGroupBox = QtWidgets.QGroupBox(Form)self.verticalGroupBox.setGeometry(QtCore.QRect(210, 20, 401, 241))self.verticalGroupBox.setObjectName("verticalGroupBox")self.verticalLayout = QtWidgets.QVBoxLayout(self.verticalGroupBox)self.verticalLayout.setContentsMargins(10, 10, 10, 10)self.verticalLayout.setObjectName("verticalLayout")self.s2__receive_text = QtWidgets.QTextBrowser(self.verticalGroupBox)self.s2__receive_text.setObjectName("s2__receive_text")self.verticalLayout.addWidget(self.s2__receive_text)self.verticalGroupBox_2 = QtWidgets.QGroupBox(Form)self.verticalGroupBox_2.setGeometry(QtCore.QRect(210, 280, 401, 101))self.verticalGroupBox_2.setObjectName("verticalGroupBox_2")self.verticalLayout_2 = QtWidgets.QVBoxLayout(self.verticalGroupBox_2)self.verticalLayout_2.setContentsMargins(10, 10, 10, 10)self.verticalLayout_2.setObjectName("verticalLayout_2")self.s3__send_text = QtWidgets.QTextEdit(self.verticalGroupBox_2)self.s3__send_text.setObjectName("s3__send_text")self.verticalLayout_2.addWidget(self.s3__send_text)self.s3__send_button = QtWidgets.QPushButton(Form)self.s3__send_button.setGeometry(QtCore.QRect(620, 310, 61, 31))self.s3__send_button.setObjectName("s3__send_button")self.s3__clear_button = QtWidgets.QPushButton(Form)self.s3__clear_button.setGeometry(QtCore.QRect(620, 350, 61, 31))self.s3__clear_button.setObjectName("s3__clear_button")self.formGroupBox1 = QtWidgets.QGroupBox(Form)self.formGroupBox1.setGeometry(QtCore.QRect(20, 340, 171, 101))self.formGroupBox1.setObjectName("formGroupBox1")self.formLayout_2 = QtWidgets.QFormLayout(self.formGroupBox1)self.formLayout_2.setContentsMargins(10, 10, 10, 10)self.formLayout_2.setSpacing(10)self.formLayout_2.setObjectName("formLayout_2")self.label = QtWidgets.QLabel(self.formGroupBox1)self.label.setObjectName("label")self.formLayout_2.setWidget(0, QtWidgets.QFormLayout.LabelRole, self.label)self.label_2 = QtWidgets.QLabel(self.formGroupBox1)self.label_2.setObjectName("label_2")self.formLayout_2.setWidget(1, QtWidgets.QFormLayout.LabelRole, self.label_2)self.lineEdit = QtWidgets.QLineEdit(self.formGroupBox1)self.lineEdit.setObjectName("lineEdit")self.formLayout_2.setWidget(0, QtWidgets.QFormLayout.FieldRole, self.lineEdit)self.lineEdit_2 = QtWidgets.QLineEdit(self.formGroupBox1)self.lineEdit_2.setObjectName("lineEdit_2")self.formLayout_2.setWidget(1, QtWidgets.QFormLayout.FieldRole, self.lineEdit_2)self.hex_send = QtWidgets.QCheckBox(Form)self.hex_send.setGeometry(QtCore.QRect(620, 280, 71, 16))self.hex_send.setObjectName("hex_send")self.hex_receive = QtWidgets.QCheckBox(Form)self.hex_receive.setGeometry(QtCore.QRect(620, 40, 71, 16))self.hex_receive.setObjectName("hex_receive")self.s2__clear_button = QtWidgets.QPushButton(Form)self.s2__clear_button.setGeometry(QtCore.QRect(620, 80, 61, 31))self.s2__clear_button.setObjectName("s2__clear_button")self.timer_send_cb = QtWidgets.QCheckBox(Form)self.timer_send_cb.setGeometry(QtCore.QRect(260, 390, 71, 16))self.timer_send_cb.setObjectName("timer_send_cb")self.lineEdit_3 = QtWidgets.QLineEdit(Form)self.lineEdit_3.setGeometry(QtCore.QRect(350, 390, 61, 20))self.lineEdit_3.setAlignment(QtCore.Qt.AlignRight|QtCore.Qt.AlignTrailing|QtCore.Qt.AlignVCenter)self.lineEdit_3.setObjectName("lineEdit_3")self.dw = QtWidgets.QLabel(Form)self.dw.setGeometry(QtCore.QRect(420, 390, 54, 20))self.dw.setObjectName("dw")self.verticalGroupBox.raise_()self.verticalGroupBox_2.raise_()self.formGroupBox.raise_()self.s3__send_button.raise_()self.s3__clear_button.raise_()self.formGroupBox.raise_()self.hex_send.raise_()self.hex_receive.raise_()self.s2__clear_button.raise_()self.timer_send_cb.raise_()self.lineEdit_3.raise_()self.dw.raise_()self.retranslateUi(Form)QtCore.QMetaObject.connectSlotsByName(Form)def retranslateUi(self, Form):_translate = QtCore.QCoreApplication.translateForm.setWindowTitle(_translate("Form", "Form"))self.formGroupBox.setTitle(_translate("Form", "串口设置"))self.s1__lb_1.setText(_translate("Form", "串口检测:"))self.s1__box_1.setText(_translate("Form", "检测串口"))self.s1__lb_2.setText(_translate("Form", "串口选择:"))self.s1__lb_3.setText(_translate("Form", "波特率:"))self.s1__box_3.setItemText(0, _translate("Form", "115200"))self.s1__box_3.setItemText(1, _translate("Form", "2400"))self.s1__box_3.setItemText(2, _translate("Form", "4800"))self.s1__box_3.setItemText(3, _translate("Form", "9600"))self.s1__box_3.setItemText(4, _translate("Form", "14400"))self.s1__box_3.setItemText(5, _translate("Form", "19200"))self.s1__box_3.setItemText(6, _translate("Form", "38400"))self.s1__box_3.setItemText(7, _translate("Form", "57600"))self.s1__box_3.setItemText(8, _translate("Form", "76800"))self.s1__box_3.setItemText(9, _translate("Form", "12800"))self.s1__box_3.setItemText(10, _translate("Form", "230400"))self.s1__box_3.setItemText(11, _translate("Form", "460800"))self.s1__lb_4.setText(_translate("Form", "数据位:"))self.s1__box_4.setItemText(0, _translate("Form", "8"))self.s1__box_4.setItemText(1, _translate("Form", "7"))self.s1__box_4.setItemText(2, _translate("Form", "6"))self.s1__box_4.setItemText(3, _translate("Form", "5"))self.s1__lb_5.setText(_translate("Form", "校验位:"))self.s1__box_5.setItemText(0, _translate("Form", "N"))self.open_button.setText(_translate("Form", "打开串口"))self.close_button.setText(_translate("Form", "关闭串口"))self.s1__lb_6.setText(_translate("Form", "停止位:"))self.s1__box_6.setItemText(0, _translate("Form", "1"))self.verticalGroupBox.setTitle(_translate("Form", "接受区"))self.verticalGroupBox_2.setTitle(_translate("Form", "发送区"))self.s3__send_text.setHtml(_translate("Form", "<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html40/strict.dtd">n"
"<html><head><meta name="qrichtext" content="1" /><style type="text/css">n"
"p, li { white-space: pre-wrap; }n"
"</style></head><body style=" font-family:'SimSun'; font-size:9pt; font-weight:400; font-style:normal;">n"
"<p style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;">123456</p></body></html>"))self.s3__send_button.setText(_translate("Form", "发送"))self.s3__clear_button.setText(_translate("Form", "清除"))self.formGroupBox1.setTitle(_translate("Form", "串口状态"))self.label.setText(_translate("Form", "已接收:"))self.label_2.setText(_translate("Form", "已发送:"))self.hex_send.setText(_translate("Form", "Hex发送"))self.hex_receive.setText(_translate("Form", "Hex接收"))self.s2__clear_button.setText(_translate("Form", "清除"))self.timer_send_cb.setText(_translate("Form", "定时发送"))self.lineEdit_3.setText(_translate("Form", "1000"))self.dw.setText(_translate("Form", "ms/次"))

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

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

相关文章

Vue渲染函数

前面的话 Vue 推荐在绝大多数情况下使用 template 来创建HTML。然而在一些场景中&#xff0c;真的需要 JavaScript 的完全编程的能力&#xff0c;这就是 render 函数&#xff0c;它比 template 更接近编译器。本文将详细介绍Vue渲染函数 引入 下面是一个例子&#xff0c;如果要…

Logstash入门简介

Logstash入门简介 介绍 Logstash是一个开源的服务器端数据处理管道&#xff0c;能够同时从多个来源采集数据&#xff0c;转换数据&#xff0c;然后将数据发送到最喜欢的存储库中&#xff08;我们的存储库当然是ElasticSearch&#xff09; 我们回到我们ElasticStack的架构图&a…

Django templates 和 urls 拆分

如果在Django项目 下面新建了blog和polls两个APP应用&#xff0c;在每个APP下面都各自新建自己的url和templates&#xff0c;那么我们需要如何进行项目配置呢&#xff1f; INSTALLED_APPS [ django.contrib.admin, django.contrib.auth, django.contrib.contenttypes, dja…

springboot怎么杀进程_线上服务平均响应时间太长,怎么排查?

线上服务平均响应时间太长&#xff0c;怎么排查&#xff1f;https://xie.infoq.cn/article/914b5c56000a3880016abd8d6前言&#xff1a;最近线上环境某个接口服务响应时间偏长&#xff0c;导致用户体验超差&#xff0c;那平时该怎么快速的排查这类问题呢&#xff1f;①、为代码…

MPEG音视频编解码之MP3编解码概述

2 MP3编解码原理 2.1 MP3音频压缩标准概述 MP3全称是动态影像专家压缩标准音频层面3&#xff08;Moving Picture Experts Group Audio Layer III&#xff09;。是当今较流行的一种数字音频编码和有损压缩格式&#xff0c;它设计用来大幅度地降低音频数据量&#xff0c;而对于…

Python实现GitBook工具

写在前面 本工具是通过Python脚本实现 GitBook 自动 生成 执行 编译 发布的功能 你可以在这里下载exe 使用 1. exe下载,并移动位置 将exe文件放在你的gitbook文件夹中,或者放在空文件夹中 2. file.md 创建 名为file.md的文件,在你要写book的目录下 注意: 这里file.md文件名…

shell脚本中用到的条件和循环语句

本博文介绍一下shell脚本中常用的条件和循环语句&#xff1a;条件语句&#xff1a;循环语句&#xff1a;示例&#xff1a;if语句&#xff1a;eg1.eg2.2.case语句&#xff1a;简单的case语句&#xff1a;配合循环的case语句&#xff1a;3.for语句&#xff1a;简单的for语句&…

processing动态代码大全_做一张动态海报需要多少步?

人们习惯性地把程序员跟设计师分成两种不同性质的人&#xff0c;好像程序员就不会有美感&#xff0c;设计师逻辑思维就一定会很弱&#xff0c;但最近几年我们发现越来越多的程序员学设计&#xff0c;设计师学编程的跨界故事。新媒体艺术家&#xff0c;邱伟豪也是其中一员&#…

手写springboot_Spring Boot 入门教程 | 图文讲解

目录一、Spring Boot 是什么二、为什么要使用 Spring Boot三、快速入门3.1 创建 Spring Boot 项目3.2 项目结构3.3 引入 Web 依赖3.4 编写第一个接口3.5 启动程序&#xff0c;验证效果四、总结五、GitHub 示例代码一、Spring Boot 是什么以下截图自 Spring Boot 官方文档&#…

lunix 安装python3

Linux下默认系统自带python2.6的版本&#xff0c;这个版本被系统很多程序所依赖&#xff0c;所以不建议删除&#xff0c;如果使用最新的Python3那么我们知道编译安装源码包和系统默认包之间是没有任何影响的&#xff0c;所以可以安装python3和python2共存 首先去python官网下载…

机器学习之朴素贝叶斯法

转载请注明出处&#xff1a;http://www.cnblogs.com/Peyton-Li/ 朴素贝叶斯法是机器学习模型中一个比较简单的模型&#xff0c;实现简单&#xff0c;比较常用。 是定义在输入空间上的随机向量&#xff0c;是定义在输出空间上的随机变量。是和的联合概率分布。训练数据集由独立同…

如何让梯形变成平行四边形_开放的课堂 创新的天地——平行四边形的面积教学片段与反思...

一、 课题的确定学生在三年级学过长方形、正方形的面积计算&#xff0c;经历过从数方格的办法得出面积计算公式的过程。因此&#xff0c;学生对于面积计算公式的推导有一定的经验和知识基础。基于上述考虑&#xff0c;我想完全放手让学生去研究如何计算平行四边形的面积。这对学…

bzoj1670【Usaco2006 Oct】Building the Moat 护城河的挖掘

1670: [Usaco2006 Oct]Building the Moat护城河的挖掘 Time Limit: 3 Sec Memory Limit: 64 MBSubmit: 387 Solved: 288[Submit][Status][Discuss]Description 为了防止口渴的食蚁兽进入他的农场&#xff0c;Farmer John决定在他的农场周围挖一条护城河。农场里一共同拥有N(8…

Vue之组件之间的数据传递

Vue的组件作用域都是孤立的&#xff0c;不允许在子组件的模板内直接引用父组件的数据&#xff0c;必须使用特定的方法才能实现组件之间的数据传递。 下列为在vue-cli创建项目中的操作 一父组件向子组件传递数据 在Vue中&#xff0c;用props向子组件传递数据。 子组件部分&#…

偶然发现一个大佬写的 React 脚手架,叫Moderate, 用起来很方便

发现一个大佬写的 React 脚手架&#xff0c;叫Moderate, 用起来很方便 Moderate&#xff0c;意思为适中的&#xff0c;适度的&#xff0c;用这个作为代号&#xff0c;主要取决于他的本名“中用”&#xff0c;其一以贯之的想法就是中庸&#xff0c;秉承着以人为本的态度&#xf…

案例 自动办公_1300张办公系列前台参考图,请您查收!

设计情报局室内设计师的灵感聚集地关注一个有格调的空间必定有一处高颜值的前台漂亮的前台很重要...是空间给人的第一印象一个独一无二的前台设计还可以提升整个空间的气质与逼格连个漂亮的前台都没有作为颜控界扛把子的设计师们还怎么混&#xff1f;SO今天小编给大家带来一份《…

目标检测_目标检测 | Anchor free的目标检测进阶版本

今天说的是《Soft Anchor-Point Object Detection》&#xff0c;其也是最近关于anchor free的目标检测的论文&#xff0c;作者来自于CMU&#xff0c;一作同样也是FSAF(2019 CVPR)的作者。该论文的出发点还是在样本选择和FPN特征选择层面。背景Anchor free是目标检测领域的一个研…

homework1

一.什么是RUP?二.什么是XP?三.什么是敏捷过程&#xff1f; 一。什么是RUP?RUP是一种完整而且完美的软件过程 1。最佳实践 &#xff08;1&#xff09;迭代式开发 &#xff08;2&#xff09;管理需求 &#xff08;3&#xff09;使用基于构件软件的体系结构 &#xff08;4&…

五个温度带的分界线_女神建筑师在拿破仑故乡打造的海景别墅,超美!超有温度!【环球设计2225期】...

生活的温度 法国建筑师阿米莉亚塔维拉(Amelia Tavella)一直对设计充满热情&#xff0c;她出生在阿雅克肖市&#xff0c;在巴黎的建筑学院学习建筑专业&#xff0c;如今她居住普罗旺斯地区的艾克斯。她说&#xff1a;“设计让我涉足很多有趣的领域并能充分发挥我的想象力。这是一…

银行it现状调研_中央银行系统行业现状调研分析及发展趋势预测报告(2019年版)...

QYResearch预测&#xff1a;2019-2025全球与中国中央银行系统市场现状及未来发展趋势【纸版价格】&#xff1a;RMB 15000【电子版(PDF)价格】&#xff1a;RMB 15000【报告篇幅】&#xff1a;112【报告图表数】&#xff1a;158【报告出版时间】&#xff1a;2019年11月报告摘要本…