You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

52 lines
1.7 KiB
C#

using CompressorXN_HelperLib;
using CompressorXN_Model.ViewModel.Plc;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Windows.Forms;
namespace CompressorXN_Communication.MyPlc
{
public class LoadPlcAddress
{
/// <summary>
/// 加载PLC配置文件
/// </summary>
/// <returns></returns>
public static DeviceInfo LoadPlcConfigFile()
{
DeviceInfo deviceInfo = new DeviceInfo
{
CommGroupList = new List<CommGroup>()
};
//获取PLC点位集合
var filePath = $"{Application.StartupPath}/MyPlc/FileConfig/PlcCommConfig.xlsx";
if (!File.Exists(filePath))
{
MessageBox.Show("PLC点位配置文件不存在");
return null;
}
deviceInfo.CommGroupList = GetPointList<CommGroup>(filePath, "通信组");
List<Variable> variableList = GetPointList<Variable>(filePath, "变量表");
foreach (var item in deviceInfo.CommGroupList)
{
item.VariableList = variableList.Where(m => m.GroupName == item.GroupName).ToList();
}
return deviceInfo;
}
/// <summary>
/// 获取点位列表
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="strFilePath"></param>
/// <param name="tbName"></param>
/// <returns></returns>
static List<T> GetPointList<T>(string strFilePath, string tbName = "dt1") where T : new()
{
var dt = ExcelHelper.GetExcel(strFilePath, tbName);
return ExcelHelper.ConvertDataTableToList<T>(dt);
}
}
}