我每隔10秒将OPC项目从OPC服务器KepServer V5读取到一个文件,但它每10秒读取两次!(我不想每10秒阅读2次,而是只读1次!)
这是我的代码。
OPCController类:
public void AddItems(string plcPath)
{
if (server.IsConnected || group.Active)
{
try
{
Opc.Da.Item[] items = new Opc.Da.Item[3];
items[0] = new Opc.Da.Item();
items[0].ItemName = “PLC1.Value1″;
items[1] = new Opc.Da.Item();
items[1].ItemName = “PLC1.Value2″;
items[2] = new Opc.Da.Item();
items[2].ItemName = “PLC1.Value3″;
group.AddItems(items);
}
catch (Exception e)
{
MessageBox.Show("Tags not read.");
}
}
}
public void ReadItems()
{
Opc.IRequest req;
group.Read(group.Items, 123, new Opc.Da.ReadCompleteEventHandler(ReadCompleteCallback), out req);
Console.ReadLine();
}
static void ReadCompleteCallback( object clientHandle, Opc.Da. ItemValueResult[] results)
{
Console.WriteLine( "Read complete" );
DateTime dataTimeNow = DateTime.Now;
foreach (Opc.Da.ItemValueResult readResult in results)
{
Console.WriteLine( "\Timestamp{0}\tValue:{1}" , (dataTimeNow.ToString("")), readResult.Value);
}
Console.WriteLine();
}Forms类:
private void startRead_btn_Click(object sender, EventArgs e)
{
int setTimerInterval = (int)this.numSetTimer.Value;
timer1.Enabled = true;
timer1.Interval = (setTimerInterval) * (1000);
timer1.Tick += new EventHandler(timer1_Tick);
timer1.Start();
startRead_btn.Enabled = false;
endRead_btn.Enabled = true;
}
private void timer1_Tick(object sender, EventArgs e)
{
opcController.ReadItems();
}输出文件:
TimeStamp: 3/2/2015 3:10:15 PM Value: 12159
TimeStamp: 3/2/2015 3:10:15 PM Value: 12162
TimeStamp: 3/2/2015 3:10:25 PM Value: 12168
TimeStamp: 3/2/2015 3:10:25 PM Value: 12169
TimeStamp: 3/2/2015 3:10:35 PM Value: 12177
TimeStamp: 3/2/2015 3:10:35 PM Value: 12178发布于 2015-03-02 23:00:47
从字面上看,您已经添加了两次相同的组:
try
{
//...
items = group.AddItems(items); //you add them HERE
group.AddItems(items); //and HERE
}通过将每个对象添加两次,它们将在一个刷新周期内从服务器读取两次。
删除任何一行,它应该只读一次。
发布于 2015-09-23 23:41:19
您只能获得2个项目的阅读结果!您的控制台正在写入它读取的每个项目,并且它只读取2。您确定您发布的代码就是生成输出的代码吗?
将ReadResult.ItemName放在console.Writeline方法中作为另一个字符串输出-您将看到情况就是这样。
foreach (Opc.Da.ItemValueResult readResult in results)
{
Console.WriteLine( "\Timestamp{0}\tValue:{1}" , (dataTimeNow.ToString("")), readResult.Value);
}另外,顺便说一句:
try{ ...
group.AddItems(items);
}
catch (Exception e)
{
MessageBox.Show("Tags not read.");
}您只是将项目添加到组中,此处没有读取方法。错误应该是其他的东西。
https://stackoverflow.com/questions/28812330
复制相似问题