首页 上一页 1 2 下一页 尾页

S7-200 ModBus从站通讯程序 点击:1607 | 回复:27



my_gongkong

    
  • 精华:0帖
  • 求助:0帖
  • 帖子:28帖 | 404回
  • 年度积分:0
  • 历史总积分:1589
  • 注册:2011年5月27日
发表于:2011-10-16 23:30:31
楼主
一直看到有些朋友在问ModBus主从站的通讯问题,今天抽空儿给大家发几篇。

事先申明,我是调用的主从站库,库本身并不是我编写的,我没有那么大的能耐。

另外,上位机是用VB编写,VB本身不是很熟,如果有什么错误,请大家海谅。

最后,这仅仅只是一个测试程序,如果各位想用到商业方面,还需要各位自己去完善。

说明:PLC从站,PC作主站,用ModBus协议进行通讯。PC机读取PLCVW区的数据;PC机还读取PLC内部I或者O地址的状态。

///////////////////////////////////////

以下是PLC程序实现,方便贴出,已转换为STL

TITLE=程序注释

Network 1 // 网络标题

// 在第一个循环周期内初始化Modbus从站协议

LD SM0.1

CALL SBR3, 1, 12, 9600, 0, 0, 128, 32, 1000, &VB0, M10.1, MB11

Network 2

// 在每个循环周期内执行Modbus 从站协议

LD SM0.0

CALL SBR1, M10.2, MB12

Network 3

LD SM0.0

MOVW AIW0, VW100

/I +54, VW100

MOVW AIW2, VW102

/I +54, VW102

MOVW AIW4, VW104

/I +54, VW104

MOVW AIW6, VW106

/I +54, VW106

Network 4

LD SM0.0

= Q0.0

Network 5

LD I0.0

= Q0.1

Network 6

LD I0.1

= Q0.2

///////////////////////////////////

以下是VB源码

Option Explicit

PrivatedeclareFunction GetTickco u* nt Lib "kernel32" () As Long

Dim x1

Dim p11, p12, p13, p14, p15, p16, p17, p18

Function CRC16(data() As Byte) As String

Dim CRC16Lo As Byte, CRC16Hi As Byte ‘CRC寄存器

Dim CL As Byte, CH As Byte ‘多项式码&HA001

Dim SaveHi As Byte, SaveLo As Byte

Dim i As Integer

Dim Flag As Integer

CRC16Lo = &HFF

CRC16Hi = &HFF

CL = &H1

CH = &HA0

For i = 0 To UBound(data)

CRC16Lo = CRC16Lo Xor data(i) ‘每一个数据与CRC寄存器进行异或

For Flag = 0 To 7

SaveHi = CRC16Hi

SaveLo = CRC16Lo

CRC16Hi = CRC16Hi \ 2 ‘高位右移一位

CRC16Lo = CRC16Lo \ 2 ‘低位右移一位

If ((SaveHi And &H1) = &H1) Then ‘如果高位字节最后一位为1

CRC16Lo = CRC16Lo Or &H80 ‘则低位字节右移后前面补1

End If ‘否则自动补0

If ((SaveLo And &H1) = &H1) Then ‘如果LSB为1,则与多项式码进行异或

CRC16Hi = CRC16Hi Xor CH

CRC16Lo = CRC16Lo Xor CL

End If

Next Flag

Next i

Dim ReturnData(1) As Byte

ReturnData(0) = CRC16Hi ‘CRC高位

ReturnData(1) = CRC16Lo ‘CRC低位

CRC16 = ReturnData

End Function

Private Sub About_Click()

frmAbout.Show

End Sub

Private Sub Form_Load() ‘初始化

Timer1.Enabled = False ‘定时器1无效

Timer1.Interval = 1000 ‘定时器1时间为1S

Timer2.Enabled = True ‘定时器2有效

Timer2.Interval = 1000 ‘定时器2时间为1S

Text1.Text = ""

Text2.Text = ""

Text3.Text = ""

Text4.Text = ""

Text5.Text = ""

Text6.Text = ""

Text8.Text = ""

Text10.Text = ""

MSComm1.CommPort = 1 ‘设定端口号

MSComm1.Settings = "9600,n,8,1" ‘设定通讯波特率

MSComm1.InBufferSize = 1024 ‘接收缓冲器大小

MSComm1.OutBufferSize = 1024 ‘输出缓冲器大小

MSComm1.InputMode = comInputModeBinary ‘以二进制传输

MSComm1.RThreshold = 1 ‘

MSComm1.SThreshold = 0

MSComm1.InputLen = 0 ‘读取接收缓冲器所有字符

MSComm1.OutBufferco u* nt = 0 ‘清空发送缓冲区

MSComm1.InBufferco u* nt = 0 ‘清空接收缓冲区

If MSComm1.PortOpen = False Then

Command3.Caption = "打开串口"

Else

Command3.Caption = "关闭串口"

End If

End Sub

Private Sub Command1_Click()

Timer1.Enabled = True

End Sub

Private Sub Command2_Click() ‘退出程序,定时器1无效

Timer1.Enabled = False

Cls

Unload Me

End Sub

Private Sub Command3_Click()

On Error Resume Next

If MSComm1.PortOpen = False Then

MSComm1.PortOpen = True

Else

MSComm1.PortOpen = False

End If

If MSComm1.PortOpen Then ‘打开关闭按钮显示文字

Command3.Caption = "关闭串口"

Else

Command3.Caption = "打开串口"

End If

If Err Then ‘打开串口失败,则显示出错信息

MsgBox Error$, 48, "错误信息"

Exit Sub

End If

End Sub

Private Sub Timer1_Timer() ‘读V存储区数据

Dim CRC() As Byte

Dim FGetData As String

Dim aa() As Byte

Dim s As String

Dim str As String

Dim i As Integer

Dim bb, cc As String

ReDim aa(5) As Byte ‘定义动态数组

aa(0) = &HC

aa(1) = &H3

aa(2) = &H0

aa(3) = &H32

aa(4) = &H0

aa(5) = &H4

CRC = CRC16(aa)

str = CRC

s = ""

For i = 1 To LenB(str)

s = s + Hex(AscB(m i* dB(str, i, 1)))

Next i

bb = Right(s, 2)

cc = m i* d(s, 1, 2)

If Len(s) < 4 Then

cc = m i* d(s, 1, 1)

End If

ReDim Preserve aa(0 To 7) As Byte

aa(6) = Val("&H" & bb)

aa(7) = Val("&H" & cc)

MSComm1.OutBufferco u* nt = 0 ‘清空输出寄存器

MSComm1.Output = aa

FGetData = ReceiveData

Text5.Text = FGetData

p11 = Val("&H" & m i* d(FGetData, 7, 4))

p12 = Val("&H" & m i* d(FGetData, 11, 4))

p13 = Val("&H" & m i* d(FGetData, 15, 4))

p14 = Val("&H" & m i* d(FGetData, 19, 4))

End Sub

Private Sub Command4_Click() ‘I状态

Dim CRC() As Byte

Dim FGetData As String

Dim aa() As Byte

Dim s As String

Dim str As String

Dim i As Integer

Dim bb, cc As String

ReDim aa(5) As Byte ‘定义动态数组

aa(0) = &HC

aa(1) = &H2

aa(2) = &H0

aa(3) = &H0

aa(4) = &H0

aa(5) = &H1

CRC = CRC16(aa)

str = CRC

s = ""

For i = 1 To LenB(str)

s = s + Hex(AscB(m i* dB(str, i, 1)))

Next i

bb = Right(s, 2)

cc = m i* d(s, 1, 2)

If Len(s) < 4 Then

cc = m i* d(s, 1, 1)

End If

ReDim Preserve aa(0 To 7) As Byte

aa(6) = Val("&H" & bb)

aa(7) = Val("&H" & cc)

MSComm1.OutBufferco u* nt = 0 ‘清空输出寄存器

MSComm1.Output = aa

FGetData = IReceiveData

p17 = Val("&H" & m i* d(FGetData, 7, 2))

p18 = Val("&H" & m i* d(FGetData, 9, 2))

End Sub

Private Sub Command5_Click() ‘Q状态

Dim CRC() As Byte

Dim FGetData As String

Dim aa() As Byte

Dim s As String

Dim str As String

Dim i As Integer

Dim bb, cc As String

ReDim aa(5) As Byte ‘定义动态数组

aa(0) = &HC

aa(1) = &H1

aa(2) = &H0

aa(3) = &H0

aa(4) = &H0

aa(5) = &H1

CRC = CRC16(aa)

str = CRC

s = ""

For i = 1 To LenB(str)

s = s + Hex(AscB(m i* dB(str, i, 1)))

Next i

bb = Right(s, 2)
正在下载,请等待……
下载附件需0积分!




雅各宾

  • 精华:23帖
  • 求助:1帖
  • 帖子:178帖 | 6966回
  • 年度积分:0
  • 历史总积分:15881
  • 注册:2002年12月10日
发表于:2011-10-17 09:18:58
1楼
S7-200 自由口通讯程序S7-200 ModBus从站通讯程序

陈石头

  • 精华:28帖
  • 求助:2帖
  • 帖子:300帖 | 9288回
  • 年度积分:0
  • 历史总积分:54987
  • 注册:2008年3月07日
发表于:2011-11-11 22:00:34
2楼

zlgang666

  • 精华:0帖
  • 求助:0帖
  • 帖子:1帖 | 52回
  • 年度积分:0
  • 历史总积分:111
  • 注册:2010年7月19日
发表于:2013-04-02 23:26:46
3楼

     好资料    谢谢楼主分享

ahljj

  • 精华:0帖
  • 求助:0帖
  • 帖子:1帖 | 806回
  • 年度积分:0
  • 历史总积分:3791
  • 注册:2002年10月03日
发表于:2013-04-15 15:53:14
4楼

S7-200 自由口通讯程序S7-200 ModBus从站通讯程序

懂一点点

  • 精华:1帖
  • 求助:2帖
  • 帖子:9帖 | 2674回
  • 年度积分:0
  • 历史总积分:1169
  • 注册:2008年5月13日
发表于:2013-04-21 23:17:13
5楼

多谢楼主,我也学习一下》》

行走天涯天远

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 56回
  • 年度积分:0
  • 历史总积分:18
  • 注册:2012年11月19日
发表于:2013-04-24 13:52:39
6楼

学习。。。。。。。。。。

老心

  • 精华:0帖
  • 求助:0帖
  • 帖子:4帖 | 1640回
  • 年度积分:0
  • 历史总积分:0
  • 注册:2004年11月11日
发表于:2013-04-24 18:07:55
7楼

S7-200 自由口通讯程序S7-200 ModBus从站通讯程序

右手边

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 17回
  • 年度积分:0
  • 历史总积分:33
  • 注册:2009年12月17日
发表于:2013-04-26 22:21:28
8楼

谢谢楼主分享。。。。。。。。。。。。。。

小刚刚诶

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 8回
  • 年度积分:0
  • 历史总积分:3
  • 注册:2012年4月13日
发表于:2013-05-08 14:55:46
9楼

赞!楼主太好啦!啊啊。。。。。

xiaobin624

  • 精华:0帖
  • 求助:1帖
  • 帖子:1帖 | 382回
  • 年度积分:0
  • 历史总积分:15
  • 注册:2012年11月04日
发表于:2013-05-15 22:19:19
10楼

看一看学习一下。。。

song1667

  • 精华:0帖
  • 求助:1帖
  • 帖子:3帖 | 102回
  • 年度积分:0
  • 历史总积分:239
  • 注册:2012年8月23日
发表于:2013-05-15 22:27:59
11楼

回复呀回复呀回复呀回复呀回复呀回复呀回复呀回复呀回复呀回复呀回复呀回复呀回复呀回复呀

ggkk777

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 15回
  • 年度积分:0
  • 历史总积分:7
  • 注册:2012年3月31日
发表于:2013-05-17 22:04:00
12楼

kkkkkkkkkkkkkkkkkkk

fulanc_48

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 4回
  • 年度积分:0
  • 历史总积分:54
  • 注册:2011年7月01日
发表于:2013-05-18 15:18:59
13楼

菜鸟学习中,加倍努力~~

yst_1204

  • 精华:0帖
  • 求助:2帖
  • 帖子:8帖 | 61回
  • 年度积分:0
  • 历史总积分:241
  • 注册:2011年4月15日
发表于:2013-05-18 15:36:27
14楼

学习中  !!!!!!!!!!

chenjian0115

  • 精华:0帖
  • 求助:0帖
  • 帖子:8帖 | 228回
  • 年度积分:2
  • 历史总积分:367
  • 注册:2008年1月26日
发表于:2013-05-22 00:33:42
15楼

西门子PLC接线全套图 

yunhai20082008

  • 精华:0帖
  • 求助:0帖
  • 帖子:1帖 | 41回
  • 年度积分:0
  • 历史总积分:1
  • 注册:2013年5月28日
发表于:2013-05-29 16:25:32
16楼

00000000000000000000

周生生1314

  • 精华:0帖
  • 求助:2帖
  • 帖子:4帖 | 100回
  • 年度积分:8
  • 历史总积分:140
  • 注册:2012年10月15日
发表于:2013-06-08 22:39:57
17楼

 

西门子PLC接线全套图 

 

a335a

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 14回
  • 年度积分:0
  • 历史总积分:23
  • 注册:2011年4月08日
发表于:2013-06-25 11:52:56
18楼

455555555555555555555555555

weijianxiong2010

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 4回
  • 年度积分:0
  • 历史总积分:200
  • 注册:2012年2月28日
发表于:2013-08-19 15:21:01
19楼

看看。。。。。。。。

bizet

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 1回
  • 年度积分:0
  • 历史总积分:1
  • 注册:2013年8月19日
发表于:2013-08-19 20:27:31
20楼

不错,看看是什么路数哦


热门招聘
相关主题

官方公众号

智造工程师
    首页 上一页 1 2 下一页 尾页