设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5417|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:9 S1 p2 J- c! w! g( k, J/ T
kanal:= DDEConnect("Excel", "Cost");
7 I6 t, |0 R1 n. ^5 i' {' I# PDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
! i- ?& U+ ]. W% t+ vDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);( O" ?$ v2 t0 `5 k; Q- n' L
DDEDisconnect(kanal);
! r8 ~- ~4 L' E: J系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
; x$ Q# z0 l; ~. [& m. `+ Z" m7 }4 J& p, E# h! k
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
" {: m: ^! g1 P+ c! t2 J3 Q3 s) c; |4 Y! o. ^

; v7 {; N' d9 i1 b+ [木有人理我么?+ p, N3 i. x/ d9 T) S3 A

: J5 m- _5 o* d% _; ?我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:% o8 Z: v! N) ^' H6 B, F

* u! ]0 k  ?1 u5 S( NDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
$ r5 B/ P6 ]1 a7 ?8 ~3 ]# L4 ?2 j. u# f1 e  J8 ^
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
7 l  f) y% ]8 @3 ?dde确实没用过,不过之前用过其它接口,不知道有没有共性。; `/ y" x* c* n/ a, z  I$ T

  s4 Y" s, ~( h6 u! t触发语句是这样写的execute("        'cost'   ...

, \" [8 k, P3 I  y谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
* @* R, H  c9 K: _' X3 b
taoyifei2000 发表于 2012-3-29 21:37
8 p( i7 G. X1 B" L2 C2 ?) ddde确实没用过,不过之前用过其它接口,不知道有没有共性。
* I1 r* ^, ^; _- `  W, F$ }: p0 |" E: v: @% _' ]# F
触发语句是这样写的execute("        'cost'   ...
, H  r8 z/ |7 A  o! P

! P8 S1 p( J2 i. S7 r5 }3 u不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。5 F0 G! W. {  I

  A3 q% t1 c, Z$ l  }9 }  C1 j诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 % X# n# x0 P. f0 G
若叶繁茂 发表于 2012-3-29 22:03 4 [1 ~* [- {* R4 u
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
. K& G8 z. Y: k+ F/ K: u
) {' H* R- Z1 x
我也没用过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 ; s- f0 c" X/ A, _7 `" x
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

% C& T5 M3 c/ R8 z谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
8 M/ A% V" a2 O! z5 u
! s" H+ P! ~  h# m! I) }我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
' G3 S0 q1 O& H* n& L4 \9 g4 X, Y按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
, o$ m' M3 W: b$ O& ?is
/ M3 h: X" Y3 t/ F7 {        xl: any;
+ C0 `7 y" U! G7 v. ~: Edo, \  G  {) {, u, P- n- z% X* q
        if ActiveX.active then) H) t% X5 E- _: ]; r" U
                xl:= activex.application;+ N% N' ^' ?2 v3 L5 m- d- e
                xl.call ("Macro_Reset");
# T  R8 J, {" q' K                activex.active:= false;
/ H8 P$ x0 b$ m, M$ G$ w        end;
% a0 [0 t  r0 v$ j" J7 O        ' o' Z! q# d5 e9 S, C' n- t
end;
% R* o4 M" r0 \( t: x+ Y* a: D8 r6 o
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~+ A; |% X) v' _, U& S
4 P) |! o  m0 D# j/ K- k
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-5-7 12:00 , Processed in 0.014206 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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