C#上位机与三菱PLC的通信06--MC协议之QnA-3E报文测试

2024-02-19 07:28

本文主要是介绍C#上位机与三菱PLC的通信06--MC协议之QnA-3E报文测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、A-3E报文回顾

1、存储区分类及访问规则 

2、命令类型

命令由主命令+子命令组成

 

3、报文结构

 2、启动mc服务器

3、创建VS项目

这节继续使用上节的VS2022的项目,增加一个方法 MCTestA3E(),具体怎么创建项目,见上节的过程。C#上位机与三菱PLC的通信04--MC协议之A-1E报文测试

 

4、报文组装与测试

 1、 读字数据,读取D100开始的2个数据, short/ushort

 

  /// <summary>/// A-3E报文测试/// </summary>private static void MCTestA3E(){// 连接Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);socket.Connect("192.168.1.7", 6000);#region 1、 读字数据,读取D100开始的2个数据, short/ushortbyte[] bytes = new byte[]{0x50,0x00,//请求副头部,固定50 000x00,// 网络号,可变,根据PLC的设置0xFF,//PLC编号,固定值0xFF,0x03,//目标模块IO编号,固定FF 030x00,// 可变,目标模块站号0x0C,0x00,  // 剩余字节长度,当前字节往后0x0A,0x00,//PLC响应超时时间,以250ms为单位计算0x01,0x04,// 成批读出,主命令0x00,0x00,// 字操作,子命令0x64,0x00,0x00,// 起始地址0xA8,// 区域代码 0x02,0x00 //读取长度     //  如果请求一个Float   2;2Float  4};socket.Send(bytes);// 暂时以这种方式来处理  byte[] respBytes = new byte[15];socket.Receive(respBytes);for (int i = 11; i < respBytes.Length; i++){// 小端处理,每2个字节作为一个数据byte[] dataBytes = new byte[2];dataBytes[0] = respBytes[i];dataBytes[1] = respBytes[++i];Console.WriteLine(BitConverter.ToInt16(dataBytes,0));}#endregion}

 2、 读字数据,读取D102开始的1个数据, float类型

 

 /// <summary>/// A-3E报文测试/// </summary>private static void MCTestA3E(){// 连接Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);socket.Connect("192.168.1.7", 6000);#region 1、 读字数据,读取D100开始的2个数据, short/ushort//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x64,0x00,0x00,// 起始地址//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //  如果请求一个Float   2;2Float  4//};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    // 小端处理,每2个字节作为一个数据//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    Console.WriteLine(BitConverter.ToInt16(dataBytes,0));//}#endregion#region 2、 读字数据,读取D102开始的1个数据, float类型//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x66,0x00,0x00,// 起始地址102//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //   请求一个Float占2个字节 //};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    //小端处理,每4个字节作为一组才是数据//    byte[] dataBytes = new byte[4];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    dataBytes[2] = respBytes[++i];//    dataBytes[3] = respBytes[++i];//    Console.WriteLine(BitConverter.ToSingle(dataBytes,0));//字节转换成浮点数//}#endregion}

 3、 读位数据,即X102开始的1个位(true/false)

/// <summary>
/// A-3E报文测试
/// </summary>
private static void MCTestA3E()
{// 连接Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);socket.Connect("192.168.1.7", 6000);#region 1、 读字数据,读取D100开始的2个数据, short/ushort//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x64,0x00,0x00,// 起始地址//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //  如果请求一个Float   2;2Float  4//};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    // 小端处理,每2个字节作为一个数据//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    Console.WriteLine(BitConverter.ToInt16(dataBytes,0));//}#endregion#region 2、 读字数据,读取D102开始的1个数据, float类型//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x66,0x00,0x00,// 起始地址102//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //   请求一个Float占2个字节 //};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    //小端处理,每4个字节作为一组才是数据//    byte[] dataBytes = new byte[4];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    dataBytes[2] = respBytes[++i];//    dataBytes[3] = respBytes[++i];//    Console.WriteLine(BitConverter.ToSingle(dataBytes,0));//字节转换成浮点数//}#endregion#region 3、 读位数据,即X102开始的1个位(true/false)byte[] bytes = new byte[]{0x50,0x00,//请求副头部,固定50 000x00,// 可变,根据PLC的设置0xFF,//PLC编号,固定值0xFF,0x03,//目标模块IO编号,固定FF 030x00,// 可变 ,目标模块站号0x0C,0x00,  // 剩余字节长度0x0A,0x00, //PLC响应超时时间,以250ms为单位计算0x01,0x4,// 成批读出 ,主命令0x01,0x00,// 子命令 - 位操作 0x02,0x01,0x00,// 起始地址,占3个字节,地址是102,用000102表示,因为是小端,前后颠倒,变成了0201000x9C,// 区域代码   X元件就是9C0x01,0x00 //读取长度     };socket.Send(bytes);byte[] respBytes = new byte[12];socket.Receive(respBytes);var obj = respBytes;string binaryStr = Convert.ToString(respBytes[11], 2).PadLeft(8, '0');//左移8位List<string> tempList = new List<string>();// 每转换一次可以拿两个位信息tempList.Add(binaryStr.Substring(0, 4));tempList.Add(binaryStr.Substring(4));for (int i = 0; i < 1; i++){Console.WriteLine(tempList[i] == "0001");}#endregion}

 4、 读字数据,即读取X100地址的int16类型数据,short或ushort类型的,如-79,35

 /// <summary>/// A-3E报文测试/// </summary>private static void MCTestA3E(){// 连接Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);socket.Connect("192.168.1.7", 6000);#region 1、 读字数据,读取D100开始的2个数据, short/ushort//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x64,0x00,0x00,// 起始地址//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //  如果请求一个Float   2;2Float  4//};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    // 小端处理,每2个字节作为一个数据//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    Console.WriteLine(BitConverter.ToInt16(dataBytes,0));//}#endregion#region 2、 读字数据,读取D102开始的1个数据, float类型//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x66,0x00,0x00,// 起始地址102//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //   请求一个Float占2个字节 //};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    //小端处理,每4个字节作为一组才是数据//    byte[] dataBytes = new byte[4];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    dataBytes[2] = respBytes[++i];//    dataBytes[3] = respBytes[++i];//    Console.WriteLine(BitConverter.ToSingle(dataBytes,0));//字节转换成浮点数//}#endregion#region 3、 读位数据,即X102开始的1个位(true/false)//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变 ,目标模块站号//    0x0C,0x00,  // 剩余字节长度//    0x0A,0x00, //PLC响应超时时间,以250ms为单位计算//    0x01,0x4,// 成批读出 ,主命令//    0x01,0x00,// 子命令 - 位操作 //    0x02,0x01,0x00,// 起始地址,占3个字节,地址是102,用000102表示,因为是小端,前后颠倒,变成了020100//    0x9C,// 区域代码   X元件就是9C//    0x01,0x00 //读取长度     //};//socket.Send(bytes);//byte[] respBytes = new byte[12];//socket.Receive(respBytes);//var obj = respBytes;//string binaryStr = Convert.ToString(respBytes[11], 2).PadLeft(8, '0');//左移8位//List<string> tempList = new List<string>();每转换一次可以拿两个位信息//tempList.Add(binaryStr.Substring(0, 4));//tempList.Add(binaryStr.Substring(4));//for (int i = 0; i < 1; i++)//{//    Console.WriteLine(tempList[i] == "0001");//}#endregion#region 4、 读字数据,即读取X100地址的int16类型数据,short或ushort类型的,如-79,35byte[] bytes = new byte[]{0x50,0x00,0x00,// 可变,根据PLC的设置0xFF,0xFF,0x03,0x00,// 可变 0x0C,0x00,  // 剩余字节长度0x0A,0x00, 0x01,0x4,// 成批读出,主操作命令0x00,0x00,// 子命令 - 字操作 0x00,0x01,0x00,// 起始地址,100用3个字节表示就是000100,小端处理前后倒置就是0001000x9C,// 区域代码   X0x01,0x00 //读取长度     };socket.Send(bytes);byte[] respBytes = new byte[13];socket.Receive(respBytes);var obj = respBytes;for (int i = 11; i < respBytes.Length; i++){// 小端处理byte[] dataBytes = new byte[2];dataBytes[0] = respBytes[i];dataBytes[1] = respBytes[++i];Console.WriteLine(BitConverter.ToInt16(dataBytes,0));}#endregion}

5、写入字数据,即按字写入地址为D100开始的2个数据short类型的,即111/222

  /// <summary>/// A-3E报文测试/// </summary>private static void MCTestA3E(){// 连接Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);socket.Connect("192.168.1.7", 6000);#region 1、 读字数据,读取D100开始的2个数据, short/ushort//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x64,0x00,0x00,// 起始地址//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //  如果请求一个Float   2;2Float  4//};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    // 小端处理,每2个字节作为一个数据//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    Console.WriteLine(BitConverter.ToInt16(dataBytes,0));//}#endregion#region 2、 读字数据,读取D102开始的1个数据, float类型//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x66,0x00,0x00,// 起始地址102//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //   请求一个Float占2个字节 //};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    //小端处理,每4个字节作为一组才是数据//    byte[] dataBytes = new byte[4];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    dataBytes[2] = respBytes[++i];//    dataBytes[3] = respBytes[++i];//    Console.WriteLine(BitConverter.ToSingle(dataBytes,0));//字节转换成浮点数//}#endregion#region 3、 读位数据,即X102开始的1个位(true/false)//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变 ,目标模块站号//    0x0C,0x00,  // 剩余字节长度//    0x0A,0x00, //PLC响应超时时间,以250ms为单位计算//    0x01,0x4,// 成批读出 ,主命令//    0x01,0x00,// 子命令 - 位操作 //    0x02,0x01,0x00,// 起始地址,占3个字节,地址是102,用000102表示,因为是小端,前后颠倒,变成了020100//    0x9C,// 区域代码   X元件就是9C//    0x01,0x00 //读取长度     //};//socket.Send(bytes);//byte[] respBytes = new byte[12];//socket.Receive(respBytes);//var obj = respBytes;//string binaryStr = Convert.ToString(respBytes[11], 2).PadLeft(8, '0');//左移8位//List<string> tempList = new List<string>();每转换一次可以拿两个位信息//tempList.Add(binaryStr.Substring(0, 4));//tempList.Add(binaryStr.Substring(4));//for (int i = 0; i < 1; i++)//{//    Console.WriteLine(tempList[i] == "0001");//}#endregion#region 4、 读字数据,即读取X100地址的int16类型数据,short或ushort类型的,如-79,35//byte[] bytes = new byte[]//{//    0x50,0x00,//    0x00,// 可变,根据PLC的设置//    0xFF,//    0xFF,0x03,//    0x00,// 可变 //    0x0C,0x00,  // 剩余字节长度//    0x0A,0x00, //    0x01,0x4,// 成批读出,主操作命令//    0x00,0x00,// 子命令 - 字操作 //    0x00,0x01,0x00,// 起始地址,100用3个字节表示就是000100,小端处理前后倒置就是000100//    0x9C,// 区域代码   X//    0x01,0x00 //读取长度     //};//socket.Send(bytes);//byte[] respBytes = new byte[13];//socket.Receive(respBytes);//var obj = respBytes;//for (int i = 11; i < respBytes.Length; i++)//{//    // 小端处理//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    Console.WriteLine(BitConverter.ToInt16(dataBytes,0));//}#endregion#region 5、写入字数据,即按字写入地址为D100开始的2个数据short类型的,即111/222byte[] bytes = new byte[]{0x50,0x00,0x00,// 可变,根据PLC的设置0xFF,0xFF,0x03,0x00,// 可变 0x10,0x00,  // 剩余字节长度0x0A,0x00, 0x01,0x14,// 成批写入0x00,0x00,// 字操作 0x64,0x00,0x00,// 起始地址0xA8,// 区域代码 0x02,0x00, //写入长度//具体的数据值,111转换成16进制就是6f,小端处理就是6f00,222小端处理就是de00(byte)(111%256),//低位(byte)(111/256%256),//高位(byte)(222%256),(byte)(222/256%256)};socket.Send(bytes);byte[] respBytes = new byte[11];socket.Receive(respBytes);var obj = respBytes;//最后2个字节是状态码,0X00,0X00是状态码,如果是0,表示成功for (int i = 9; i < respBytes.Length; i++){// 小端处理,每2个字节作为一个数据byte[] dataBytes = new byte[2];dataBytes[0] = respBytes[i];dataBytes[1] = respBytes[++i];if (BitConverter.ToInt16(dataBytes,0) == 0){Console.WriteLine("写入成功");}}#endregion}

 6、写入字数据,即按字写入地址为D102开始的1个数据,即float类型的13.9

 /// <summary>/// A-3E报文测试/// </summary>private static void MCTestA3E(){// 连接Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);socket.Connect("192.168.1.7", 6000);#region 1、 读字数据,读取D100开始的2个数据, short/ushort//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x64,0x00,0x00,// 起始地址//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //  如果请求一个Float   2;2Float  4//};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    // 小端处理,每2个字节作为一个数据//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    Console.WriteLine(BitConverter.ToInt16(dataBytes,0));//}#endregion#region 2、 读字数据,读取D102开始的1个数据, float类型//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 网络号,可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变,目标模块站号//    0x0C,0x00,  // 剩余字节长度,当前字节往后//    0x0A,0x00,//PLC响应超时时间,以250ms为单位计算//    0x01,0x04,// 成批读出,主命令//    0x00,0x00,// 字操作,子命令//    0x66,0x00,0x00,// 起始地址102//    0xA8,// 区域代码 //    0x02,0x00 //读取长度     //   请求一个Float占2个字节 //};//socket.Send(bytes);暂时以这种方式来处理  //byte[] respBytes = new byte[15];//socket.Receive(respBytes);//for (int i = 11; i < respBytes.Length; i++)//{//    //小端处理,每4个字节作为一组才是数据//    byte[] dataBytes = new byte[4];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    dataBytes[2] = respBytes[++i];//    dataBytes[3] = respBytes[++i];//    Console.WriteLine(BitConverter.ToSingle(dataBytes,0));//字节转换成浮点数//}#endregion#region 3、 读位数据,即X102开始的1个位(true/false)//byte[] bytes = new byte[]//{//    0x50,0x00,//请求副头部,固定50 00//    0x00,// 可变,根据PLC的设置//    0xFF,//PLC编号,固定值//    0xFF,0x03,//目标模块IO编号,固定FF 03//    0x00,// 可变 ,目标模块站号//    0x0C,0x00,  // 剩余字节长度//    0x0A,0x00, //PLC响应超时时间,以250ms为单位计算//    0x01,0x4,// 成批读出 ,主命令//    0x01,0x00,// 子命令 - 位操作 //    0x02,0x01,0x00,// 起始地址,占3个字节,地址是102,用000102表示,因为是小端,前后颠倒,变成了020100//    0x9C,// 区域代码   X元件就是9C//    0x01,0x00 //读取长度     //};//socket.Send(bytes);//byte[] respBytes = new byte[12];//socket.Receive(respBytes);//var obj = respBytes;//string binaryStr = Convert.ToString(respBytes[11], 2).PadLeft(8, '0');//左移8位//List<string> tempList = new List<string>();每转换一次可以拿两个位信息//tempList.Add(binaryStr.Substring(0, 4));//tempList.Add(binaryStr.Substring(4));//for (int i = 0; i < 1; i++)//{//    Console.WriteLine(tempList[i] == "0001");//}#endregion#region 4、 读字数据,即读取X100地址的int16类型数据,short或ushort类型的,如-79,35//byte[] bytes = new byte[]//{//    0x50,0x00,//    0x00,// 可变,根据PLC的设置//    0xFF,//    0xFF,0x03,//    0x00,// 可变 //    0x0C,0x00,  // 剩余字节长度//    0x0A,0x00, //    0x01,0x4,// 成批读出,主操作命令//    0x00,0x00,// 子命令 - 字操作 //    0x00,0x01,0x00,// 起始地址,100用3个字节表示就是000100,小端处理前后倒置就是000100//    0x9C,// 区域代码   X//    0x01,0x00 //读取长度     //};//socket.Send(bytes);//byte[] respBytes = new byte[13];//socket.Receive(respBytes);//var obj = respBytes;//for (int i = 11; i < respBytes.Length; i++)//{//    // 小端处理//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    Console.WriteLine(BitConverter.ToInt16(dataBytes,0));//}#endregion#region 5、写入字数据,即按字写入地址为D100开始的2个数据short类型的,即111/222//byte[] bytes = new byte[]//{//    0x50,0x00,//    0x00,// 可变,根据PLC的设置//    0xFF,//    0xFF,0x03,//    0x00,// 可变 //    0x10,0x00,  // 剩余字节长度//    0x0A,0x00, //    0x01,0x14,// 成批写入//    0x00,0x00,// 字操作 //    0x64,0x00,0x00,// 起始地址//    0xA8,// 区域代码 //    0x02,0x00, //写入长度//    //具体的数据值,111转换成16进制就是6f,小端处理就是6f00,222小端处理就是de00//    (byte)(111%256),//低位//    (byte)(111/256%256),//高位//    (byte)(222%256),//    (byte)(222/256%256)//};//socket.Send(bytes);//byte[] respBytes = new byte[11];//socket.Receive(respBytes);//var obj = respBytes;最后2个字节是状态码,0X00,0X00是状态码,如果是0,表示成功//for (int i = 9; i < respBytes.Length; i++)//{//    // 小端处理,每2个字节作为一个数据//    byte[] dataBytes = new byte[2];//    dataBytes[0] = respBytes[i];//    dataBytes[1] = respBytes[++i];//    if (BitConverter.ToInt16(dataBytes,0) == 0)//    {//        Console.WriteLine("写入成功");//    }//}#endregion#region 6、写入字数据,即按字写入地址为D102开始的1个数据,即float类型的13.9float value = 13.9f;byte[] bytes = new byte[]{0x50,0x00,0x00,// 可变,根据PLC的设置0xFF,0xFF,0x03,0x00,// 可变 0x10,0x00,  // 剩余字节长度0x0A,0x00,0x01,0x14,// 成批写入0x00,0x00,// 字操作 0x66,0x00,0x00,// 起始地址,占3个字节,102转换成16进制的小端格式是6600000xA8,// 区域代码 0x02,0x00, //写入长度,float的长度是2个//具体的数据值,float占4个字节,分别是66,66,5e,41BitConverter.GetBytes(value)[0],BitConverter.GetBytes(value)[1],BitConverter.GetBytes(value)[2],BitConverter.GetBytes(value)[3]};socket.Send(bytes);byte[] respBytes = new byte[11];socket.Receive(respBytes);var obj = respBytes;//最后2个字节是状态码,0X00,0X00是状态码,如果是0,表示成功for (int i = 9; i < respBytes.Length; i++){// 小端处理,每2个字节作为一个数据byte[] dataBytes = new byte[2];dataBytes[0] = respBytes[i];dataBytes[1] = respBytes[++i];if (BitConverter.ToInt16(dataBytes,0) == 0){Console.WriteLine("写入成功");}}#endregion}

5、小结

原创真的不容易,走过路过不要错过,点赞关注收藏又圈粉,共同致富

原创真的不容易,走过路过不要错过,点赞关注收藏又圈粉,共同致富。

原创真的不容易,走过路过不要错过,点赞关注收藏又圈粉,共同致富。

 

这篇关于C#上位机与三菱PLC的通信06--MC协议之QnA-3E报文测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/723938

相关文章

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

C#使用MQTTnet实现服务端与客户端的通讯的示例

《C#使用MQTTnet实现服务端与客户端的通讯的示例》本文主要介绍了C#使用MQTTnet实现服务端与客户端的通讯的示例,包括协议特性、连接管理、QoS机制和安全策略,具有一定的参考价值,感兴趣的可... 目录一、MQTT 协议简介二、MQTT 协议核心特性三、MQTTNET 库的核心功能四、服务端(BR

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr

C#特性(Attributes)和反射(Reflection)详解

《C#特性(Attributes)和反射(Reflection)详解》:本文主要介绍C#特性(Attributes)和反射(Reflection),具有很好的参考价值,希望对大家有所帮助,如有错误... 目录特性特性的定义概念目的反射定义概念目的反射的主要功能包括使用反射的基本步骤特性和反射的关系总结特性

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

通过C#获取Excel单元格的数据类型的方法详解

《通过C#获取Excel单元格的数据类型的方法详解》在处理Excel文件时,了解单元格的数据类型有助于我们正确地解析和处理数据,本文将详细介绍如何使用FreeSpire.XLS来获取Excel单元格的... 目录引言环境配置6种常见数据类型C# 读取单元格数据类型引言在处理 Excel 文件时,了解单元格

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel