Java从西门子PLC(S7-1200 、S7-1500)读取数据,整理存库示例
时间: 2024-01-07 17:03:20 浏览: 55
以下是一个Java通过Snap7库从S7-1200 PLC读取数据的示例代码,并将数据整理后存储到MySQL数据库中:
```java
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import com.snap7.client.S7Client;
public class Snap7Example {
public static void main(String[] args) {
// 连接PLC
S7Client client = new S7Client();
int result = client.ConnectTo("192.168.0.1", 0, 1);
if (result != 0) {
System.out.println("连接PLC失败");
return;
}
// 读取数据
byte[] data = new byte[20];
result = client.DBRead(1, 0, 20, data);
if (result != 0) {
System.out.println("读取数据失败");
return;
}
// 解析数据
int value1 = S7Client.DBX(1, 0, 0, data);
int value2 = S7Client.DBW(1, 2, data);
float value3 = S7Client.DBD(1, 4, data);
// 存储数据到数据库
try (Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb", "root", "password")) {
PreparedStatement stmt = conn.prepareStatement("INSERT INTO mytable (value1, value2, value3) VALUES (?, ?, ?)");
stmt.setInt(1, value1);
stmt.setInt(2, value2);
stmt.setFloat(3, value3);
stmt.executeUpdate();
} catch (SQLException e) {
System.out.println("存储数据到数据库失败:" + e.getMessage());
}
// 断开PLC连接
client.Disconnect();
}
}
```
在以上示例代码中,我们首先连接PLC,然后使用`DBRead`方法读取指定DB块的数据。接着,我们使用`S7Client`提供的方法解析数据,并将数据存储到MySQL数据库中。最后,我们断开与PLC的连接。需要注意的是,以上示例代码仅供参考,实际应用中需要根据具体需求进行修改。