设为首页收藏本站

最大的系统仿真与系统优化公益交流社区

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5512|回复: 7

[求助] 请教关于em-Plant做client的DDEExecute的应用

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
& s6 H* ]: j0 u. i8 J! pkanal:= DDEConnect("Excel", "Cost");
% y# Q, Q+ e3 h2 u/ T, EDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);/ s6 G9 ?6 ?  p( p% w) s
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
( q# P1 t/ s8 S7 E( T2 d- O8 UDDEDisconnect(kanal);
3 q, @! J- H$ C系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
/ \5 P" s8 O9 R0 h
% s# Z/ Q$ x* A( Q+ _% [请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 6 @  i1 i  ^  \" e: I9 y" p

/ j" n; l# \. y9 C# x! J* u* X0 k, {6 m2 C
木有人理我么?1 U5 T& X7 ?! H$ [0 @
! G1 [' B# w+ C
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:4 |7 E' ]6 ?- b( x

2 N( s* i: K) ^" K3 \- O- n& dDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);& M1 B: x  ]0 m7 d$ e, @
* ^4 r- A9 O3 B5 w8 x; I* D& j: ]
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 . `* Z- u3 v& t/ ?0 r- |
dde确实没用过,不过之前用过其它接口,不知道有没有共性。$ U. Q. ]4 K$ p
$ y) |% x2 q1 s! v9 {
触发语句是这样写的execute("        'cost'   ...

( A8 b* Q' X1 g8 [5 Z! B9 L谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 6 }1 Q9 P- l" |$ V5 [- ~7 \
taoyifei2000 发表于 2012-3-29 21:37
, V+ m& Z' E6 @* W' U. @8 B5 Bdde确实没用过,不过之前用过其它接口,不知道有没有共性。
2 D, S$ x1 L5 U! F/ b0 _9 R/ o" q. y* b
触发语句是这样写的execute("        'cost'   ...

: k$ Q/ Y, D- Q) ?: T0 |8 r9 W7 b7 N# R4 A) i- i
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。9 R! J1 @  s4 o+ a2 l0 y5 }
6 x: B8 ]8 J# p
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
5 N" v( r9 n9 E  F2 m% j
若叶繁茂 发表于 2012-3-29 22:03
3 h2 Z( P* K4 ?: |- [: y9 |& q不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
0 C$ _$ E. c! T4 z. U. F- z

2 [4 x( y) Z, w$ ^我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的 觉得效果还行。。。
发表于 2012-3-29 23:15:32 | 显示全部楼层
还有我按照你的语句写了一下 电脑并不沉默 但是只是单纯的把 Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value 这一段内容作为字串赋值到excel里面了 囧。。。不知道为啥。。。
 楼主| 发表于 2012-4-2 20:50:13 | 显示全部楼层
五五 发表于 2012-3-29 23:13
. o* ^/ v; R/ v! P& v8 H% Z* B6 k我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
( E) P2 N( ?+ m6 M
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
* C3 K* B9 \& d/ g* F8 ]! @
) ~1 x+ f$ |. i: Y. p我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
/ R) D, R4 L6 x按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:7 v* d  k% ~: g! a' _
is$ d) O: `9 [1 r1 q! o( l+ J
        xl: any;) z' F* V( ~/ N. E4 P& M' w
do2 p+ D% ~" e/ |# K0 _/ u2 q4 [8 r- x
        if ActiveX.active then7 j+ f2 o* I; u+ U
                xl:= activex.application;
  b1 Q/ {$ f: f4 i3 N5 X5 ~$ [                xl.call ("Macro_Reset");6 Z. G# T" K" I+ z1 _
                activex.active:= false;+ ]/ s# J( ^* ]3 c  Q8 c
        end;
9 P7 q+ j" @. m/ e8 g  h# ^          U' ]* L) s: b; C
end;4 y9 C3 s+ j# Q. n1 P* D3 t

' u4 c: |3 `0 D4 g; k显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
" m7 i$ [# E& S; F* V  J& |7 F  V+ d3 j  k6 L4 A3 `, N. Y
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|手机版|SimulWay 道于仿真   

GMT+8, 2026-6-21 21:38 , Processed in 0.012995 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表