西门子S7-1200 PLC与C#(上位机)通讯(TCP协议)

只要可以读写寄存器就可以了
首先建立连接了,如何编码?看了很久的手册也不是很明白,以前用过三菱的。
可以举个列子,高速我方法就可乐

西门子S7-1200紧凑型PLC在当前的市场中有着广泛的应用,由于其性价比高,所以常被用作小型自动化控制设备的控制器,这也使得它经常与第三方的设备(扫描枪、打印机等设备进行通讯。因为没有第三方的设备,这里就以超级终端为例介绍自由口通讯。1.控制系统原理2.硬件需求S7-1200PLC目前有3种类型的CPU:1)S7-1211CCPU。2)S7-1212CCPU。3)S7-1214CCPU。这三种类型的CPU都可以连接三个串口通信模版。本例中使用的PLC硬件为:1)PM1207电源(6EP1332-1SH71)2)S7-1214C(6ES7214-1BE30-0XB0)3)CM1241RS232(6ES7241-1AH30-0XB0)3.软件需求1)编程软件Step7BasicV10.5(6ES7822-0AA0-0YA0)4.组态我们通过下述的实际操作来介绍如何在Step7BasicV10.5中组态S7-1214C和超级终端通信。点击桌面上的“TotallyIntegratedAutomationPortalV10”图标,打开如下图:首先需要选择“Createnewproject”选项,然后在“Projectname:”里输入PTP;在“Path:”修改项目的存储路径为“C:\”;点击“Create”,这样就创建了一个文件PTP的新项目。创建后的窗口如下图所示:点击门户视图左下角的“ProjectView”切换到项目视图下,如下图:打开后,在“Devices”标签下,点击“Addnewdevice”,在弹出的菜单中输入设备名“PLC_1”并在设备列表里选择CPU的类型。选择后如下图:插入CPU后,点击CPU左边的空槽,在右边的“Catalog”里找到“Communication”下的RS232模块,拖拽或双击此模块,这样就把串口模块插入到硬件配置里,接下来就需要配置此RS232模块硬件接口参数,选择RS232模块,在其下方会出现该模块的硬件属性配置窗口,在属性窗口里有两个选项,一个是“general”;一个是“RS232interface”。在“General”里包括了此模块的“项目信息”和“订货信息”;而在“RS232interface”里包括“项目信息”、“端口的配置”、“发送信息的配置”、“接收信息的配置”和“硬件识别号”。在这里我们选择“RS232interface”,在“端口”配置的选项里,进行端口的参数配置,波特率为:9600;校验方式:无;数据位为:8;停止位:1;硬件流控制:无;等待时间:1ms设置参数如下图:此时确认一下“硬件识别号”为11。此时,完成了硬件的组态,接下来需要编写串口通讯程序,在这里我们实现两个功能:一、S7-1200发送数据给超级终端;二、超级终端发送数据给S7-1200对于第一个功能:S7-1200发送数据给超级终端,实际上是S7-1200是数据的发送方,超级终端是数据的接收方,对于S7-1200需要编写发送程序;而对于超级终端来说,只要打开超级终端程序,配置硬件接口参数与前面S7-1200的端口参数一只即可。下面的步骤将具体介绍此功能实现的步骤:①、在PLC中编写发送程序。在项目管理视图下双击“Device”下的程序块下的Main(OB1),打开OB1,在主程序中调用SEND_PTP功能块如下图所示:(注:SEND_PTP在指令库下的扩展指令中通讯指令下)要对SEND_PTP赋值参数,首先需要创建SEND_PTP的背景数据块和发送缓冲数据块,双击“Devices”——>“PLC_1”——>“ProgramBlock”——“Addnewblock”,在弹出的串口命名DB_Send_PTP,选择DB块,在Type后选择“SEND_PTP(SFB113)”插入背景DB后,再插入发送缓冲DB块,重复上面的步骤,只是在选择DB类型为“GlobalDB”,并去掉“Symbolicaccessonly”选项勾(这样可以对该DB块进行直接地址访问),并取名该DB块为DB_SEND_BUFF。建好这两个DB块后,双击打开DB_SEND_BUFF预先定义好要发送的数据,如下图所示:
温馨提示:内容为网友见解,仅供参考
第1个回答  2017-08-10
使用USS协议、MODBUS、PROBIFUS都可以。本回答被提问者采纳
第2个回答  2018-06-14

写了一段代码,时我项目上用过的,希望能收获财富分:



int Handle1;
bool EntLink;
long ScanCount;

WinTcpS7_1K.PlcClient PLC = new WinTcpS7_1K.PlcClient();

public void Form1_Load(System.Object sender, System.EventArgs e)
{
short i = 0;
this.CenterToScreen();
cmbReadMry.Items.Clear();
cmbReadMry.Items.Add("I");
cmbReadMry.Items.Add("Q");
cmbReadMry.Items.Add("M");
cmbReadMry.Items.Add("DB");
cmbReadMry.Items.Add("AI");
cmbReadMry.Items.Add("AQ");
cmbWriteMry.Items.Clear();
cmbWriteMry.Items.Add("I");
cmbWriteMry.Items.Add("Q");
cmbWriteMry.Items.Add("M");
cmbWriteMry.Items.Add("DB");
cmbWriteMry.Items.Add("AI");
cmbWriteMry.Items.Add("AQ");
cmbBitMry.Items.Clear();
cmbBitMry.Items.Add("I");
cmbBitMry.Items.Add("Q");
cmbBitMry.Items.Add("M");
cmbBitMry.Items.Add("DB");
cmbReadType.Items.Clear();
cmbReadType.Items.Add("W_INT16");
cmbReadType.Items.Add("W_UINT16");
cmbReadType.Items.Add("D_DINT32");
cmbReadType.Items.Add("D_HEX32");
cmbReadType.Items.Add("D_REAL32");
cmbReadType.Items.Add("W_BIN16");
cmbReadType.Items.Add("B_CHAR8");
cmbReadType.Items.Add("B_BYTE8");
cmbWriteType.Items.Clear();
cmbWriteType.Items.Add("W_INT16");
cmbWriteType.Items.Add("W_UINT16");
cmbWriteType.Items.Add("D_DINT32");
cmbWriteType.Items.Add("D_HEX32");
cmbWriteType.Items.Add("D_REAL32");
cmbWriteType.Items.Add("W_BIN16");
cmbWriteType.Items.Add("B_CHAR8");
cmbWriteType.Items.Add("B_BYTE8");

for (i = 0; i <= 7; i++)
{
cmbBit.Items.Add("Bit" + System.Convert.ToString(i));
}
cmbReadMry.SelectedIndex = 2;
cmbWriteMry.SelectedIndex = 2;
cmbBitMry.SelectedIndex = 2;
cmbBit.SelectedIndex = 0;
cmbReadType.SelectedIndex = 0;
cmbWriteType.SelectedIndex = 0;
lstRead.Items.Clear();
}


public void butLink_Click(System.Object sender, System.EventArgs e)
{
short re = 0;
string restr = "";
re = PLC.EntLink(txtLocalIP.Text.Trim(), System.Convert.ToUInt16(txtLocalPort.Text), txtRemoteIP.Text.Trim(), System.Convert.ToUInt16(txtRemotePort.Text), System.Convert.ToUInt16(0), System.Convert.ToUInt16(1), "DEMO", ref Handle1);
txtReLink.Text = re.ToString();
if (re == 0)
{
EntLink = true;
MessageBox.Show("PLC联接成功!");
}
else
{
EntLink = false;
MessageBox.Show("PLC联接失败: " + restr);
}
}



public void butClose_Click(System.Object sender, System.EventArgs e)
{
short re = 0;
EntLink = false;
re = PLC.DeLink(Handle1);
txtReClose.Text = re.ToString();
}



public void butRead_Click(System.Object sender, System.EventArgs e)
{
short re = 0;
short i = 0;
object[] RD = null;
RD = new object[System.Convert.ToUInt16(txtReadCnt.Text)];
if (!EntLink)
{
MessageBox.Show("还未与PLC建立联接!");
return;
}
int var1 = cmbReadMry.SelectedIndex + 1;
            WinTcpS7_1K.PlcClient.PlcMemory mry = (WinTcpS7_1K.PlcClient.PlcMemory)var1;
var1 = cmbReadType.SelectedIndex + 1;
            WinTcpS7_1K.PlcClient.DataType typ = (WinTcpS7_1K.PlcClient.DataType)var1;

re = PLC.CmdRead(Handle1, mry, typ, System.Convert.ToUInt16(txtReadBlock.Text), System.Convert.ToUInt16(txtReadAdd.Text), System.Convert.ToUInt16(txtReadCnt.Text), ref RD);

txtReRead.Text = re.ToString();
lstRead.Items.Clear();
for (i = 0; i < RD.Length; i++)
{
if (!ReferenceEquals(RD[i], null))
{
lstRead.Items.Add(RD[i]);
}
else
{
lstRead.Items.Add("0");
}
}
}


public void butWrite_Click(System.Object sender, System.EventArgs e)
{
short re = 0;
short i = 0;
string[] temp = null;
object[] WD = null;
if (!EntLink)
{
MessageBox.Show("还未与PLC建立联接!");
return;
}
WD = new object[System.Convert.ToUInt16(txtWriteCnt.Text)];
temp = txtWrite.Text.Split('\n');
for (i = 0; i < WD.Length; i++)
{
if (i >= temp.Length)
{
WD[i] = 0;
}
else
{
WD[i] = temp[i].Trim();
}
}
int var1 = cmbWriteMry.SelectedIndex + 1;
WinTcpS7_1K.PlcClient.PlcMemory mry = (WinTcpS7_1K.PlcClient.PlcMemory)var1;
var1 = cmbWriteType.SelectedIndex + 1;
WinTcpS7_1K.PlcClient.DataType typ = (WinTcpS7_1K.PlcClient.DataType)var1;

re = PLC.CmdWrite(Handle1, mry, typ, System.Convert.ToUInt16(txtWriteBlock.Text), System.Convert.ToUInt16(txtWriteAdd.Text), System.Convert.ToUInt16(txtWriteCnt.Text), ref WD);

txtReWrite.Text = re.ToString();
}




public void butBitTest_Click(System.Object sender, System.EventArgs e)
{
if (!EntLink)
{
MessageBox.Show("还未与PLC建立联接!");
return;
}
bool rd = false;
short re = 0;
int var1 = cmbBitMry.SelectedIndex + 1;
WinTcpS7_1K.PlcClient.PlcMemory mry = (WinTcpS7_1K.PlcClient.PlcMemory)var1;

re = PLC.Bit_Test(Handle1, mry, System.Convert.ToUInt16(txtBitBlock.Text), System.Convert.ToUInt16(txtBitAdd.Text), System.Convert.ToUInt16(cmbBit.SelectedIndex), ref rd);

txtBitTest.Text = rd.ToString();
txtReBit.Text = re.ToString();
}





public void butBitSet_Click(System.Object sender, System.EventArgs e)
{
if (!EntLink)
{
MessageBox.Show("还未与PLC建立联接!");
return;
}
short re = 0;

int var1 = cmbBitMry.SelectedIndex + 1;
WinTcpS7_1K.PlcClient.PlcMemory mry = (WinTcpS7_1K.PlcClient.PlcMemory)var1;

re = PLC.Bit_Set(Handle1, mry, System.Convert.ToUInt16(txtBitBlock.Text), System.Convert.ToUInt16(txtBitAdd.Text), System.Convert.ToUInt16(cmbBit.SelectedIndex));

txtReBit.Text = re.ToString();
}


public void butBitRst_Click(System.Object sender, System.EventArgs e)
{
if (!EntLink)
{
MessageBox.Show("还未与PLC建立联接!");
return;
}
short re = 0;
int var1 = cmbBitMry.SelectedIndex + 1;
WinTcpS7_1K.PlcClient.PlcMemory mry = (WinTcpS7_1K.PlcClient.PlcMemory)var1;

re = PLC.Bit_Reset(Handle1, mry, System.Convert.ToUInt16(txtBitBlock.Text), System.Convert.ToUInt16(txtBitAdd.Text), System.Convert.ToUInt16(cmbBit.SelectedIndex));

txtReBit.Text = re.ToString();
}




public void butReadString_Click(System.Object sender, System.EventArgs e)
{
if (!EntLink)
{
MessageBox.Show("还未与PLC建立联接!");
return;
}
string re = "";
re = PLC.CmdReadString(Handle1, WinTcpS7_1K.PlcClient.PlcMemory.DR, System.Convert.ToUInt16(txtStrDB.Text), System.Convert.ToUInt16(txtBuffAdd.Text), System.Convert.ToUInt16(txtBuffSize.Text));
txtReadString.Text = re;
}


public void butWriteString_Click(System.Object sender, System.EventArgs e)
{
if (!EntLink)
{
MessageBox.Show("还未与PLC建立联接!");
return;
}
short re = 0;
re = PLC.CmdWriteString(Handle1, WinTcpS7_1K.PlcClient.PlcMemory.DR, System.Convert.ToUInt16(txtStrDB.Text), System.Convert.ToUInt16(txtBuffAdd.Text), System.Convert.ToUInt16(txtBuffSize.Text), txtWriteString.Text);
txtReWriteString.Text = re.ToString();
}

第3个回答  2017-10-27
之前在论坛上看到了一个叫 WinTcpS7_1K 的DLL,特地跟公司的S7-1500的PLC连接了一下,居然能用,可以试一下;

西门子s7-1200除了和本地触摸屏通讯,还要和上位机通讯,
是的。上位机通常用于监视和控制PLC系统,以实现更高级别的数据处理和操作。通过与上位机通信,可以实现数据传输、监控和诊断、远程访问等功能。常见的上位机通信方式包括以太网通信、串口通信(如RS-232、RS-485)、PROFIBUS、Modbus等。

彻底搞定西门子1200PLC之通讯篇
胡炜,20年经验电气工程师,主打西门子1200\/1500 PLC、西门子WinCC V7.4上位机、ABB机器人等三大自控核心设备设计。从业20多年,具有20余套设备研发设计的丰富经验,应用过Profinet通信,Modbus\/RTU通信,Modbus\/TCP通信,TCP\/IP通信,S7通信等多种通信协议,从事有PID为主的流体自动控制、伺服系统的生产线...

上位机与PLC之间的通信
西门子PLC支持串口通信,但在新系列中已逐渐取消内置串口,需通过扩展模块实现。串口通信简洁低成本,但传输效率低。西门子早期通信主要为Profibus DP,但上位机无法直接与之通信,因此,常用的串口通信方案涉及配置参数以适应不同环境。以太网通信为主流,西门子PLC通信协议包括S7协议和Profinet协议。Profinet为总...

S7 PLC与 上位机之间可以采用TCP\/IP,Socket通讯吗
可以的,不过不支持公开的Modbus tcp协议,西门子的是profinet协议。国产的矩形PLC,支持公开的Modbus tcp 主从协议。socket编程见附件文档。

上位机和西门子s7通讯延迟
可能是通讯协议原因。上位机和西门子S7之间的通讯延迟可能是上位机和S7之间的通讯协议不够高效,可以考虑使用更高效的通讯协议。S7是西门子自己的协议,是一个基于以太网与S7系列的西门子PLC通讯的开源库。

上位机通信,PLC连接不上是怎么回事呀?
1、我们首先要Ping一下PLC的IP地址,保证物理网络是正常的,一定要记住Ping通只能证明网络没问题,并不能代表一定可以通信。2、西门子S7协议是基于TCP的,所以我们接下来可以用网络调试助手去连接PLC,IP地址填写PLC的IP地址,端口号填写102。3、用通信测试平台测试变量,记住这里最好先测试M存储区,如MD...

S7 PLC与 上位机之间可以采用TCP\/IP,Socket通讯吗
请问楼上的,plc采用TCP\/IP时和pc机通讯,其不是像局域网中的两台pc机通讯。都是基于TCP\/IP的,当然硬件也可以通用了。关键时PLC中的设置,这个通讯设置好像与td同plc通讯时相似,通过设置V中的参数快完成的。

西门子PLC如何连接电脑上位机通讯
1、首先,电脑网卡设置:设置IP段和PLC网段,如下图所示,然后进入下一步。2、其次,完成上述步骤后,设置PLC的IP地址,见下图,然后进入下一步。3、接着,完成上述步骤后,运行系统管理控制台工具,并在配置(默认参数)下创建一个新的“New_PortCpS7_000”文件,如下图所示,然后进入下一步。4、...

关于c#做上位机与西门子200plc连接与通信
一般PLC都会提供一套通讯协议,你根据协议去和PLC通讯,一般通过串口

S7 PLC与 上位机之间可以采用TCP\/IP,Socket通讯吗
用鼠标双击 [ \\\\<LOCAL> ] ,搜索本机OPC服务器:选择 [ S7200.OPCServer ],再选择 [ 浏览服务器 ]在OPCSERVER中添加变量 完成上述步骤后就可以实现S7-200和WINCC进行TCP\/IP以及SCOKET通讯了。二、S7-300和400与上位机进行TCP\/IP以及SCOKET通讯 进入PLC硬件组态中,对CP模板进行设置。主要是创建一...

相似回答