设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4162|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
9 j& j6 |2 T6 I/ A: Ykanal:= DDEConnect("Excel", "Cost");
' `$ C5 |: }. ~( oDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
3 t7 c: C" a) h. p* C+ J1 b7 nDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);6 N/ L" [* S" G4 X
DDEDisconnect(kanal);
- ~( d! Q$ |. V/ O% r# V" ?- C系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
: s7 n# b$ Q( T8 r! K, L  O
9 u) x9 S' C# ^" H请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
" C# {( j. f& F* Z8 B+ y; b; Y4 X  o( F
" }7 s/ g& {2 |4 O+ H" w- s
木有人理我么?9 p3 @; y* r4 _' x
9 b& r% o. Q5 s3 a5 X
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:+ |7 [, ~+ f8 [9 J+ [
. g- ^( h/ s& ^* [  \
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);. R1 ~4 Y. A; C2 G0 i

0 b3 ^. O( r' I3 Z! P, c但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 5 Q7 {1 k+ J8 t0 J' A/ g9 }2 f
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
+ ?9 Z% C+ `3 L5 Z. c0 m
# K9 g0 ^) G& [& n5 b- J触发语句是这样写的execute("        'cost'   ...

" q& l) J1 r4 B/ o谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
. h! |- ^% H0 g. P7 i! ]4 U. ^. m" C
taoyifei2000 发表于 2012-3-29 21:37 ) T0 R5 d0 N: w# t' ^  @5 a- p! x8 \( U
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
0 Y0 ~4 o; o& n& e1 Z/ C  _# N% D3 u4 h6 Q- c
触发语句是这样写的execute("        'cost'   ...
: r0 J/ }1 n' R' ~% c

) O) b/ ^- X/ Q8 X# O% U3 z( a不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
* r0 U5 f5 `( Y  D' I! Q  W/ s( @7 B4 F
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 ! q+ l. o6 [: v- ]: _( ]
若叶繁茂 发表于 2012-3-29 22:03 9 X  C5 U( @- P. v. b: t3 E
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

2 O8 S3 z, ?8 C8 h
) B+ I2 S0 k) n: O1 U% q! ]9 U我也没用过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
$ E9 c9 ^) K* {! w. r我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

% v5 ?( u' B' p8 T* U" N# h/ C3 B谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
2 |; D, s1 |9 A* ^, H# X. p- M/ l1 p% ?  V
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。3 P+ O1 e# h& D; v5 R$ O, j; Q0 h
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:9 }1 O" W- P9 }8 P/ l, e
is0 L& u- w) D& Z9 E% c  i
        xl: any;) V/ n' q$ J/ c9 j7 E. e- l. k2 W
do$ c3 ~0 y: k0 ]  X& Z5 d
        if ActiveX.active then
4 g+ H# V& G- n5 t2 i+ F5 n: K                xl:= activex.application;# V- S( a9 r  c. y
                xl.call ("Macro_Reset");! ]) N1 k& ~+ u- e! m& D
                activex.active:= false;
/ L. B3 P! J4 v; t! e! J: T0 d7 v        end;
3 @0 s8 S2 Z* ?" W4 d; }        5 a3 J, {1 q" ~5 }' r+ G
end;
/ ~! m! [! m) i2 K$ U8 v" P# W+ r8 G6 f1 C
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
0 L; y1 |/ m! f: h/ v) i% k* e7 N* p# X2 v$ y+ \
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-7-5 02:54 , Processed in 0.016438 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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