设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5227|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
) R2 }. f8 a0 M3 okanal:= DDEConnect("Excel", "Cost");
4 _4 f; R1 B7 `+ L9 _9 JDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
  T& w# q% X0 R6 nDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);2 l9 |: K) b# I) n' P1 b9 b# ~
DDEDisconnect(kanal);7 U) Q# A1 \  i. V9 F) R
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
. a' |8 v- V: J1 f8 i  {; ~$ W+ C6 p
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 2 ^; m7 ?5 l# a# y- s

  n! }5 F0 K4 @3 |. @# v! J9 I; Z
$ T8 E6 \  m: T  b" x, f; k* ]木有人理我么?6 H1 u5 z% F$ u$ V
2 i2 R5 n3 ]2 a2 ]$ q$ s
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:  ~0 }' L9 g7 a8 V  I; {
# z, h$ Z0 w6 b( C1 W
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
" O5 f8 V+ a# ?7 y  w4 g% e( {  I2 W4 B( j$ L/ ~
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 6 w+ o( @& ]' w7 z  S. A6 p8 ]
dde确实没用过,不过之前用过其它接口,不知道有没有共性。! a/ Y5 ~: H8 {! v' u' W: k: b# ]
1 ^8 d4 ?" l) }1 {; h3 i/ Q: ?" E
触发语句是这样写的execute("        'cost'   ...
% G: P: u6 z% h0 X! A2 F- F
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
! j$ N3 G  i9 L1 X: o: b3 ?
taoyifei2000 发表于 2012-3-29 21:37
" R1 \, \7 ~) p9 K2 Odde确实没用过,不过之前用过其它接口,不知道有没有共性。: m9 Q  a* J& `9 A, t- x/ ~) h

6 Y* l. c) ?- T2 r% t触发语句是这样写的execute("        'cost'   ...

0 M& ]) J& U: H" _2 C! U& K; Q$ y" }4 U' `& h5 E
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
7 }+ j# @4 f+ ~5 r1 x
3 M% D' Y# U; ~: T$ x: Y& m诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
. f  F8 k# I' G6 G0 t+ m
若叶繁茂 发表于 2012-3-29 22:03
0 q7 }7 v( I4 U8 T* l( ?+ G不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

7 c. Z5 i4 _$ G' ]# j2 s* z2 p/ a6 H' K
我也没用过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
( w, h; Z+ x3 o; c* [% v我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

+ J4 Y/ R( e3 n- G8 Q+ Z谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
; f: p; H2 J0 `: ?1 j" T. F
4 v2 Y" J* E2 [: y; @我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
- @1 L; t9 Q2 q按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:+ v1 o$ ?/ a8 w! i" y4 {
is
* w- u& d) q. c; D) \        xl: any;3 ^" j; c6 _4 O4 N$ G  d* U
do
+ h; t2 ~+ _0 Z( ]$ M" ]/ ?6 C) _        if ActiveX.active then6 [) O& o" z2 Z
                xl:= activex.application;( ^9 E. ]2 n- M# ~" n$ ]9 Q% ~' j# e
                xl.call ("Macro_Reset");5 o9 o% ?6 Z: _/ `  Y9 ]4 u
                activex.active:= false;
' M$ R+ C  I1 E$ \$ Q( |: R) M/ R        end;
. I5 z+ f+ L0 J0 n7 x/ d; e       
- Y, N8 C0 I$ }# h& H, Tend;7 K& f3 _4 V; U' H( x. x

) y; q9 Y" ~2 C& v. \) n; W( A' U8 X显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
! A0 E: M5 B7 @' W+ I" a/ g% ~* {: @2 F) x
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-13 21:34 , Processed in 0.013980 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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