设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4911|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:7 [9 v) u  i* u$ f
kanal:= DDEConnect("Excel", "Cost");7 N. x! {( g. E! j
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
, M) J. i0 i# K+ GDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
# N0 }! R1 U4 P) b* w, d$ }DDEDisconnect(kanal);5 [6 q. y0 t, U5 g, M
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
& n7 R; y8 R0 F5 i
5 y! f. G3 o- K3 g6 ], H, T; l; ~请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
. `# B# ~: W, c2 u# a  L: {  u& N% C" `

; Z- s" {0 _- ~木有人理我么?/ r- h6 e% K) P$ I, Y
( Z1 b! }$ M* k2 q
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:* z* [: c7 Q+ ]( G2 U. a

2 `4 |4 ~) ^+ h! S* _+ ~DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);1 X3 U& _0 A8 Z4 D3 c
  j: I. a  i4 A0 e
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
5 R7 U; t) ]- u3 q) |! i- edde确实没用过,不过之前用过其它接口,不知道有没有共性。
0 P5 S7 u; z" ~9 w
* |( F2 H" [; Z# Z4 D触发语句是这样写的execute("        'cost'   ...
2 z; ~! d8 Y% ?/ T. i4 Y# @
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
9 R( f$ n0 @% U# q, c4 b5 \" o
taoyifei2000 发表于 2012-3-29 21:37 1 @: ]: b, g% g8 R
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
6 ]+ ^/ k$ r% _9 w$ w) y" ~
. x  V: L8 j. j$ d$ i触发语句是这样写的execute("        'cost'   ...
' j, ?4 b; c, J8 n
- k3 Z# _. k5 i  z& w% h7 q4 @
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
; n% I5 x# M& h" z4 W. u; ~- |1 v/ C
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
5 t. D, z+ k6 j3 V* P  u, [
若叶繁茂 发表于 2012-3-29 22:03 8 V' z  L& d: m4 c  |) _, @
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

$ v' C% M1 ?! K" }. y* H) R; Q, G3 j9 }) o6 Y1 t- y+ _
我也没用过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 # v. i! S% k8 [2 r  a
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

) F5 O% F: y* i3 u, \% x谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
3 A4 b  G3 b4 `/ z3 _( Y! K7 }3 {
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。. u& [) `5 C1 M' g* K2 K
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
1 R0 `: V0 ~) ]8 @* Xis# s8 J$ @; L/ f- l, w
        xl: any;
  S+ V8 d1 K1 o. y3 A5 @2 b$ xdo
2 u# l6 C& N: I$ W; c0 d. L4 Q3 \        if ActiveX.active then! d, ^- ^, m" ], I/ n9 A
                xl:= activex.application;
% _  Z( ^. ]. h! G" ?' U" T                xl.call ("Macro_Reset");. \& k$ L, e; z# p
                activex.active:= false;
. J. g& z2 R6 m( R% P: v6 s  `        end;* Y7 M, X' ^7 ~- y2 [
        7 u5 }9 m4 N, J+ x6 z. ]7 E1 w* x
end;8 Q  [* u, d+ |/ t6 y1 W

9 R0 }& J/ \' p2 x2 x- S3 I显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
9 _+ N9 |- c, [; e+ |: _7 V* j" [& c3 r
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-12-14 22:17 , Processed in 0.021053 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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