# !/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. RabbitMQ管理界面使用之手动送数据

    目录 1. 找到相应的队列, 点击进入详情 2. 找到Publish Message项,填写自定义数据 3. 发送数据 4. 发送成功 5. 接收 1. 找到相应的队列, 点击进入详情 2. 找到Pu ...

  2. 国产DP4398 兼容替代CS4398 24Bit 192KHz数模转换芯片

    CS4398是一款24Bit/192K Hz规格的解码芯片,它具有120分贝以上的讯噪比和动态范围,采用一个高级专用多位Delta-Sigma调制器,并整合了失配噪声整形技术.今天来讲讲它的国产替代型 ...

  3. word文件打开报错:abnormal program termination

    部分word文件打开后报错 处理方法 1.更改默认打印机 2.调整开机启动项 取消该项:cyberkI guard service的开机自启动 (赛博昆仑安全软件) 3.调整word的COM加载项

  4. C# Socket 通信

    C# Socket通信 Socket通信主要分为两部分,服务端和客户端,其中服务端和客户端都具有接收消息和发送消息的功能,具体通信流程就是服务端先去监听一个端口号,等待客户端的连接,客户端通过指定IP ...

  5. Tomcat异常处理机制

    声明 源码基于Spring Boot 2.3.12中依赖的Tomcat 异常例子 tomcat中返回错误页面目前主要是以下两种情况. 执行servlet发生异常 程序中主动调用response.sen ...

  6. Oracle之关于sql_load导入数据

    平时在工作当中经常需要统计数据,客户会提供文本或者列表,需要导入到数据库中进行数据统计碰撞等,这时候需要用到批量导入数据,之前用kettle或者plsqldeveloper的odbc导入工具,性能不行 ...

  7. linux:day01 计算机基础 随堂笔记 马

    本课程内容目录(前30天) 一,计算机基础 1,机械硬盘是比较慢的,如果有条件的话,还是换成固态硬盘有个120G就够了,价钱大概500G 700元 2,视频从一台机器拷贝到另外一台机器,复制的时候要限 ...

  8. SAP abap外部断点

    如图所示:

  9. 升级TLS1.3

    初衷:简简单单在网站上挂个单点登录,先在本地跑起来,然后再放到服务器上.然而问题来了: 请求被中止: 未能创建 SSL/TLS 安全通道 简简单单的百度一下,只需要加上这行就可以了~Easy Serv ...

  10. DataTable操作汇总

    1.排序 DataTable dt = new DataTable(); dt.Columns.Add("Name"); dt.Columns.Add("Age" ...