设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5103|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:8 }! G# k8 r. t& _# n9 A: N4 a
kanal:= DDEConnect("Excel", "Cost");: J9 J& t% ^2 G$ Z* t
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
/ u0 ]9 B, W4 Y! F! ]  TDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);$ I7 {4 U9 S# `
DDEDisconnect(kanal);
* `# }& W7 w% {7 y) e2 N系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
: q% b, D4 Y/ J) Y7 W) q  X) I! U0 Z. N$ U4 `& q( r
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
: T" [& N/ F2 \+ T; C0 W
' Y  J  w3 U: \* H! b1 U5 ~* Q
1 |* S! C3 L4 y4 h木有人理我么?1 t6 m) B' @9 ]# E! A$ r

1 p9 q8 f' A7 U, J$ C" I4 m1 e3 m7 ?我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:$ u- n; e5 {% t  m. {3 E/ t) O# Y; B

. G% [9 }/ |+ @8 h- YDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
  B" G  a: G7 o' p1 l' z
) P' F3 c3 Y( z0 h5 \/ [9 e但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
8 ?& i2 L7 V8 w0 o$ Xdde确实没用过,不过之前用过其它接口,不知道有没有共性。
5 Y; r8 q) l2 \& x" Q/ q2 G4 {: b/ W0 G
触发语句是这样写的execute("        'cost'   ...

/ m8 E/ V* D  `谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 ) a$ o4 K* G) J5 F- K3 I
taoyifei2000 发表于 2012-3-29 21:37 , ]( ?4 o% |# b, _% M
dde确实没用过,不过之前用过其它接口,不知道有没有共性。9 _% q* n8 |1 _  J9 K% N. L
$ ~+ w4 V3 v. G
触发语句是这样写的execute("        'cost'   ...
0 _% x: f7 h  o' S# z4 M  E

2 u0 ?! R5 U- G不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
9 I# w* m0 y) P7 n2 f4 f. m
8 {; e2 K7 u$ R诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 * ~6 V& a5 E: P1 J- h2 U3 c
若叶繁茂 发表于 2012-3-29 22:03 5 \2 p3 G( ]7 H) K$ @; [3 c0 W
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
% ~% [! f1 Q' v  }* T- z0 k. F

0 P2 {% h  T3 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
: q) h( f6 T# P! @* z我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
5 y; Z1 m2 ]5 N, M" D: \
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
) M1 m# ~; j8 s. }. a. v& Z
7 b0 N8 D: n- H. l+ N) a我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
. o- F6 H: M4 ~' q% l按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:/ \4 E9 @* k  w0 S8 X
is
* G0 S7 s; ]* S/ p1 q: @        xl: any;
0 D4 W7 |5 ^4 L. z( Hdo3 U$ f% `/ a- o% @+ X, }( A4 t
        if ActiveX.active then
" y0 L7 M4 }* f% F, h) ~; T                xl:= activex.application;
+ n: [( F' B" K/ m+ [' |4 k                xl.call ("Macro_Reset");4 n4 U& b% n& x% g" ~5 L! B
                activex.active:= false;; S& y1 Y9 L% R( C' C
        end;
" y" u3 ^& p1 s  V- v- `        , L; L# u" `8 x) _
end;
, s8 x3 K+ c/ ?$ D; q% g
8 A9 i! z+ X  u+ ^2 f6 m4 k. g显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
) L6 g& e$ ~) S) @0 Z7 i
* o4 H. B/ d& q- r/ ]期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-6 04:04 , Processed in 0.019594 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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