设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4402|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
# }% ~2 V. p; c( Tkanal:= DDEConnect("Excel", "Cost");7 U+ [. N+ ^& O# H7 g3 P
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
3 N1 W" c" d' J  QDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
0 E1 g  k; z6 T' L6 L5 I. fDDEDisconnect(kanal);4 C+ ~9 l  A* ~/ H9 U" c. z/ a
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
  H& s$ k* M  \; J
3 Z! C( \. R5 M' s$ L请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
3 o- B7 k% h% Q% e3 A4 P- H1 }/ Y7 K- v3 P: ]
4 i6 D. g- U0 V* f' E
木有人理我么?7 D; `0 S; ?0 L3 }2 S
1 W* ^6 T) `# r/ m
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
8 H; g/ D# V3 D8 L# u9 n
9 w  I5 H2 |7 ?* @/ gDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
% z. l5 O5 P7 f# p& t9 s: c7 y9 \' p7 x  J& K
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 2 I2 l: ]. Y) p- a
dde确实没用过,不过之前用过其它接口,不知道有没有共性。/ \0 ]4 N4 W; o# v' K. w" ^. D! S

; m, J$ P& x) H2 Z4 f7 m( B1 a触发语句是这样写的execute("        'cost'   ...

) w+ f" h. N0 @0 a# P8 o5 ~6 t5 p谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 6 b8 u8 i; D( g5 I" C& `
taoyifei2000 发表于 2012-3-29 21:37
1 H' Y& q  Q! C5 k- k1 gdde确实没用过,不过之前用过其它接口,不知道有没有共性。3 l2 X, N) Y0 M6 I/ _+ o/ \3 B; P7 m

3 M1 R/ ^1 p0 u2 V6 D7 Y触发语句是这样写的execute("        'cost'   ...

6 v/ g+ w2 S8 V3 q' Q6 A8 k  C& U# P
2 k6 K# ?1 r; C& g不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
4 R& @$ ?& L, A
1 q" |  U6 |3 F" n  U) q诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 & U0 F3 ?# r/ b& I8 b+ R1 _
若叶繁茂 发表于 2012-3-29 22:03
  i/ `# f+ f4 s3 ]  N. q6 k3 G0 @& U不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

& i3 ~# \. E  X: V
* T4 p0 U9 y: R( T我也没用过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 $ b% {6 C5 [2 ]  @
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
  z( C+ c4 K0 H3 i: Y/ E: a; \
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。3 g! i" F7 ^$ f& e
. t6 l6 `2 G, B- G* _9 b) t
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。% j! r2 Z3 C- L! A8 o+ F, O  a
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
# U6 f) I1 x- \* D& n  O' v/ J5 kis9 {2 Y1 X; g/ I0 i& ]7 x
        xl: any;
; L7 ]$ N3 H+ h" S' H6 x7 m7 \do
4 |- D* I) x9 P        if ActiveX.active then
/ f# ~" |6 x7 T& @" q. z  n, ?                xl:= activex.application;
4 _0 g7 l! i( `: |( t8 h                xl.call ("Macro_Reset");3 X! K& E# x+ Y
                activex.active:= false;
! N: B! }1 g( |        end;+ \, b* w: ~1 {7 t* N9 N5 }$ k( n/ |
        : c) F$ z: J& F
end;
7 A  {5 ?/ V" j& Y/ @' W" y
/ L! W( z) Q) I; D. w  p/ C1 d显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~% F7 I9 \* a) m  B2 A/ k8 q& i

1 H% ^$ J4 I; g1 \: c) H3 v期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-11 00:34 , Processed in 0.014997 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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