设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4913|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:4 {/ t" s; {  f/ U6 _
kanal:= DDEConnect("Excel", "Cost");) G8 D" W4 O9 I
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);5 n& p9 r/ _! H$ {
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);6 @: D; I7 _' ^& [  u3 J
DDEDisconnect(kanal);
. i  [1 t: s$ u9 w3 p3 P系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
1 K' l3 I( `$ ^& o
- Z5 P: i* {& ^2 j! @请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 2 W0 c# j, n0 m  `/ D
/ Y1 S. Q5 Z5 I  S& t
: X. t$ `9 W* B' _* X5 s
木有人理我么?
6 g0 e+ z& ]2 L& z) o+ a  h/ u/ j  _& r6 C
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:  |3 j0 @9 B2 B. p
8 w# @+ ?% }# X1 h2 I
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);9 }4 e; _+ W1 `, Y
# o: c9 t  ?' e* G  t9 S, ?+ a
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 * F; m; P5 N9 `% S8 J% r- A; t
dde确实没用过,不过之前用过其它接口,不知道有没有共性。' T9 d& _, S" v. S
7 G6 Y' I7 G5 _% R
触发语句是这样写的execute("        'cost'   ...
8 ^8 v7 F" ~1 T4 v, }  G7 [$ E" e
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
7 P4 I/ H$ {# w) s! h
taoyifei2000 发表于 2012-3-29 21:37 & A) v8 D7 \' X9 k$ D5 m
dde确实没用过,不过之前用过其它接口,不知道有没有共性。- L5 e2 O0 J0 w
& x+ T7 L0 N$ L: |: q: }
触发语句是这样写的execute("        'cost'   ...

5 N0 n8 J! Q) K3 a
4 x; @  j: e; i7 @; l不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
2 H9 \+ l: S! _& d# w+ p/ q2 M& [. L: {$ h" O+ U; p+ U+ Q5 R! d
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
2 [! X5 Y. D% K+ @1 l5 W; y
若叶繁茂 发表于 2012-3-29 22:03
* w$ r- e' A1 J7 ^/ x4 M不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

' V. y1 r4 t, M: F: J
! \6 i( E/ o" u' x% A# b% `我也没用过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
8 ?4 W: k# i$ R& N. M3 Z: K我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
9 z; n, W3 d" d  |( t
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。6 S& ?. A- w  l! G% d: S4 V9 |/ I
6 I3 h" a' o  E0 K" g# b" r
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。# |7 {/ ?- D% d9 I9 k) K8 Y" o
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:& w: D4 }/ ~$ Y/ v7 L
is
( }, d9 k6 L6 {+ w        xl: any;
3 V$ v, b  d8 {. \do% ]% J' }% p8 x
        if ActiveX.active then3 L- A; s4 g) m1 h& N( g
                xl:= activex.application;
- q9 Z& R7 J/ @0 c: u; o' F7 G! @# k                xl.call ("Macro_Reset");
& a3 ~7 w# x' w/ z2 i/ V                activex.active:= false;) F0 {$ Q9 d: O' o+ W% e% Y2 B* t
        end;
) B* k$ m4 W2 P2 f0 K; n1 H        6 \* b  |$ ?+ y: a- z
end;
' ?& [  X9 @2 t& ^9 R( Y9 {. W" c3 \0 E
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~  S. }2 U5 n+ i  c
8 j7 ?, \) ?$ D$ G
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-12-15 09:57 , Processed in 0.015362 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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