# !/usr/bin/python
# -*- coding: UTF-8 -*-
import sys
import os TESTCASE = os.path.dirname(os.path.abspath(__file__))
DIR = os.path.dirname(TESTCASE)
sys.path.append(DIR)
import logging
import socket
import struct
import binascii
import time, datetime
import re
import importlib
from common_util.mysql_conn_pool import MysqlConn importlib.reload(sys) class ServerSocket(object): def __init__(self, host, port):
self.host = host
self.port = port
self.s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
self.s.bind((self.host, self.port))
self.s.listen(5)
self.conn, self.addr = self.s.accept()
logging.info('conn,addr------', self.conn, self.addr)
print('conn,addr------', self.conn, self.addr) # 接收数据
def recv_data(self):
try:
time.sleep(3)
data = self.conn.recv(2048)
data = binascii.b2a_hex(data)
logging.info('jieshoudaodiyicishuju', data)
if data:
data = str(data.decode('utf-8'))
print('decode', data)
logging.info('decode', data)
return data
except Exception as e:
print(e)
logging.info(e) # 发送数据
def send_data(self):
req = struct.pack('8B', int('01', 16), int('03', 16),
int('00', 16), int('00', 16), int('00', 16),
int('10', 16), int('44', 16), int('06', 16))
return self.conn.sendall(req) # 解析数据
def parse_data(self, modbus_param):
# modbus_param = b'010320001c7fff00fb012b028d0000005b000026f802737fff7fff7fff7fff7fff7fff5c5c'
# modbus_param = modbus_param.decode('utf-8')
a, b = modbus_param.split('010320')
st1 = re.findall(r'\w{4}', b)
logging.info(st1)
wind_speed = int(st1[0], 16) / 10 # 风速
temp = int(st1[2], 16) / 10 # 温度
petch = int(st1[3], 16) / 10 # 贴片,组件温度
humidity = int(st1[4], 16) / 10 # 湿度
total_radiation = int(st1[5], 16) # 总辐(当前辐射强度)
wind_direction = int(st1[6], 16) # 风向
sum_radiation = int(st1[7], 16) # 总累(辐射日累计)
pressure = int(st1[8], 16) # 气压
if len(str(pressure)) > 4:
pressure = pressure / 10 ** (len(str(pressure)) - 4)
else:
pass
carbon_dioxide = int(st1[9], 16) # 二氧化碳
param_list = [wind_speed, temp, petch, humidity, total_radiation,
wind_direction, sum_radiation, pressure,
carbon_dioxide]
logging.info('jiexideshuju:', param_list)
print('jiexideshuju:', param_list)
return param_list def insert_modbus_nums(self, param_list):
sql = '''INSERT INTO `bromake`.`pv_read_modbus` ( `wind_speed`, `temp`,
`petch`, `humidity`, `total_radiation`, `wind_direction`,
`sum_radiation`, `pressure`, `carbon_dioxide` )
VALUES
(%s,%s,%s,%s,%s,%s,%s,%s) '''.format(
param_list[0], param_list[1],
param_list[2], param_list[3],
param_list[4], param_list[5],
param_list[6], param_list[7],
param_list[8])
try:
conn = MysqlConn()
conn.insert_one(sql, )
conn.commit()
conn.close()
except Exception as e:
print(e) # 关闭连接
def close_conn(self):
return self.s.close() # host, port = '0.0.0.0', 12001 # socket = ServerSocket(host, port) def main(host, port):
socket = ServerSocket(host, port)
recv_data = socket.recv_data()
logging.info('zoudao recv_data', type(recv_data), recv_data)
print('zoudao recv_data', type(recv_data), recv_data)
# recv_data = recv_data.decode('utf-8')
recv_data1 = recv_data[0:4]
logging.info('recv_data1', recv_data1, type(recv_data1))
print('recv_data1', recv_data1, type(recv_data1))
if recv_data1 == '0103':
list_param = socket.parse_data(recv_data)
socket.insert_modbus_nums(list_param)
else:
socket.send_data()
recv_data = socket.recv_data()
# recv_data = recv_data.decode('utf-8')
recv_data1 = recv_data[0:4]
if recv_data1 == '0103':
list_param = socket.parse_data(recv_data)
socket.insert_modbus_nums(list_param)
else:
pass
socket.close_conn()
time.sleep(10) if __name__ == '__main__':
while True:
time1 = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
print(time1)
time.sleep(60 * 5)
time2 = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
print(time2)
main('0.0.0.0', 12001)
print('==========main==============')
logging.info('==========main==============')

通过modbus+socket+GPRS采集硬件数据的更多相关文章

  1. Django项目:CMDB(服务器硬件资产自动采集系统)--12--08CMDB采集硬件数据日志记录

    #settings.py # ————————01CMDB获取服务器基本信息———————— import os BASEDIR = os.path.dirname(os.path.dirname(o ...

  2. Django项目:CMDB(服务器硬件资产自动采集系统)--11--07CMDB文件模式测试采集硬件数据

    #settings.py # ————————01CMDB获取服务器基本信息———————— import os BASEDIR = os.path.dirname(os.path.dirname(o ...

  3. Django项目:CMDB(服务器硬件资产自动采集系统)--07--06CMDB测试Linux系统采集硬件数据的命令02

    #settings.py """ Django settings for AutoCmdb project. Generated by 'django-admin sta ...

  4. Django项目:CMDB(服务器硬件资产自动采集系统)--06--06CMDB测试Linux系统采集硬件数据的命令01

    #base.py # ————————01CMDB获取服务器基本信息———————— from config import settings #配置文件 class BasePlugin(object ...

  5. Django项目:CMDB(服务器硬件资产自动采集系统)--05--05CMDB采集硬件数据的插件

    #__init__.py # ————————05CMDB采集硬件数据的插件———————— from config import settings import importlib # —————— ...

  6. Django项目:CMDB(服务器硬件资产自动采集系统)--10--06CMDB测试Linux系统采集硬件数据的命令05

    cd /py/AutoClient/bin python3 auto-client.py /usr/local/python3/bin/pip install requests python3 aut ...

  7. Django项目:CMDB(服务器硬件资产自动采集系统)--09--06CMDB测试Linux系统采集硬件数据的命令04

    root 123456 ip addr init 0 root 123456 ip addr root 123456 python3 yum -y install zlib-devel bzip2-d ...

  8. Django项目:CMDB(服务器硬件资产自动采集系统)--08--06CMDB测试Linux系统采集硬件数据的命令03

    https://www.virtualbox.org/wiki/Downloads https://mirrors.aliyun.com/centos/7/isos/x86_64/ http://ww ...

  9. Java后台创建Socket服务接收硬件终端发送的数据

    最近项目中有遇到后台接收硬件终端发送的数据并解析存储的需求,代码总结如下(有时间再来一一讲解,最近比较忙): @Override public void start() { ExecutorServi ...

  10. 为一个支持GPRS的硬件设备搭建一台高并发服务器用什么开发比较容易?

    高并发服务器开发,硬件socket发送数据至服务器,服务器对数据进行判断,需要实现心跳以保持长连接. 同时还要接收另外一台服务器的消支付成功消息,接收到消息后控制硬件执行操作. 查了一些资料,java ...

随机推荐

  1. open-local部署和使用

    Open-Local简介 Open-local 是阿里巴巴开源,由多个组件构成的本地磁盘管理系统,目标是解决当前kubernetes本地存储能力缺失问题. Open-Local包含四大类组件: • S ...

  2. java使用apache-commons-lang3生成随机字符串(可自定义规则)

    在日常开发中,我们经常会遇到生成随机字符串的需求.可能是大小写字母+数字,也可能是其他各种字符.作为一个常用功能,我们完全没必要自己实现,有很多优质的类库已经做的很完善了.本文介绍的就是apache- ...

  3. js实现数字每三位加逗号

    需求: 一个数字,比如 1234,23456.23 实现每三位加逗号 改成如下形式: 1234 => 1,234 23456.23 => 23,456.23 方法一 function fo ...

  4. grep展示相邻行

    grep搜索展示匹配行的上面或下面相邻的行: # grep -A 1 pattern file -A选项,是 After 的缩写,表示除了展示匹配行之外,还要展示出匹配行下面的若干行.而示例中的 -A ...

  5. android控制台应用binder通讯

    在android root环境下,有一个后台服务server进程需要提供接口给控制台应用client调用,本来想用socket方式来做的,后台发现android有更高效的方式来实现.那就是binder ...

  6. 读后笔记 -- Java核心技术(第11版 卷 II) Chapter3 XML

    3.1 XML Introduction An XML document is made up of elements. An element can have attributes (key/val ...

  7. UART4模板

    #define UART4_Bps 9600 #define UART4_RecSize 20 uchar UART4_RecData[UART4_RecSize];uchar UART4_Loc; ...

  8. ESP32-IDF 在vscode环境搭建

    前言 由于许多的未知原因,我尝试过许多网上教程,在vscode上搭建ESP-IDF环境,但结果是耗费了大把时间,结果还非常不理想. 在参考了(一)esp32开发环境搭建(VSCode+IDF实现单步调 ...

  9. for in | for in 比较 解释 | 以后找知识点先从这里面搜索

    const obj = { a: 1, b: 2, c: 3 } for (let i in obj) { console.log(i) // a // b // c } for (let i of ...

  10. 全链路压测SOP

    压测模型构建:人工 线上(大促)流量数据 (数据脱敏) 日常流量数据 业务方新的特性产生的变更数据 友商做过的事情 压测模型构建:自动 流程包括:录制-清洗-回放 (目前能做好的公司非常少) 压测标准 ...