设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4623|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:  ^% W. t, P" P2 B) Z# K2 C
kanal:= DDEConnect("Excel", "Cost");
9 w9 M, C+ X; V3 z, k7 YDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
1 }5 h. |4 \+ ~6 T/ V, j- ADDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
% E! d  \% `5 k! F  WDDEDisconnect(kanal);
' j9 F' `: z6 k: g9 Y' _! Y系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
8 b: T* B$ v) |/ O' ?+ }$ L+ H2 }) X; u6 C) S8 T" O  ?
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 0 P. @2 ?' z  U& X7 F7 [0 N

! y  w& F$ z2 x) _, w6 n6 @6 @( j/ Z+ K* n/ E8 y6 ^  [& X
木有人理我么?
8 j( U% G4 J9 K4 I& ?' M" c
1 H6 K: y: k' _: n  |我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:2 U! k0 Z7 i7 N* W6 A- l4 r
8 o0 C; g& n$ j# h! S; z# l9 a' l
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);3 U+ i- x; }9 {* k4 @0 I- y

+ G* M! \9 X  B! C  ]但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
1 S# L# I1 z6 q: g4 h+ ?4 Idde确实没用过,不过之前用过其它接口,不知道有没有共性。
6 _! g2 X+ ]% S  J% r- {
- K' i6 I7 U' X, T2 Y触发语句是这样写的execute("        'cost'   ...

. L) f; i. Z' H) I8 b8 q谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 ' e' `! r3 L1 f
taoyifei2000 发表于 2012-3-29 21:37
) D1 G% K$ V& Y5 I5 Sdde确实没用过,不过之前用过其它接口,不知道有没有共性。0 E; v/ X8 w, V0 `# f. F1 F/ s) l
" `( b/ _& Y) n9 [- z( j8 c" B
触发语句是这样写的execute("        'cost'   ...
4 k2 j/ |5 N; J* ^
2 V4 k0 v. k; f
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
& [8 \' x3 M8 B/ G
6 M: I2 g8 O: W/ n, l- h7 @; C& V4 g诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
: |% a0 s1 P* m9 X. v& g7 v
若叶繁茂 发表于 2012-3-29 22:03
2 b( Y1 T. m6 f6 W% e不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
# ~  n# }$ Q+ F+ }  _# q

/ o' c3 ?9 |3 |8 [我也没用过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 $ y" o/ ?, W  g9 L: u  n
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
& k: s* Q7 l5 a( S8 A- G* x
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。$ o& U4 o' E0 I9 n: k  S

0 ]2 Q+ x$ Q& @+ S( R我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
% B: o! p* N# {按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
% z. F! t: h% b: O( |2 F: lis
* w1 k6 K1 j! ~! a5 j  ~        xl: any;
& N: P3 b; h- a' Z% _* g# G% B3 h8 `do" @7 G) `2 M( s. F" }' H4 o* c# s
        if ActiveX.active then
8 L. B( X, N8 D0 b( F7 T                xl:= activex.application;4 J3 q2 ]  q" q  _: O& {" ~: X
                xl.call ("Macro_Reset");. w# m# l7 M3 `, c
                activex.active:= false;, e- T1 V. v6 Z
        end;5 p/ ^- U. E: X# V$ b* w+ o0 G) v
        ) C* a& h* Y+ C+ ~
end;
( F8 i3 ~8 L6 }; p. U+ B% G( d1 E# h+ f4 h* s
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
( n- I9 o; o: d+ F$ g; I7 D
4 I! k6 ~) p5 G$ `( S. U( a4 |. M% d期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-10-18 06:11 , Processed in 0.015533 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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