设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 3685|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
/ R( r# g( X* z* o6 S9 Lkanal:= DDEConnect("Excel", "Cost");
5 e7 ]  q; L: o! xDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);" L5 k+ d8 w" S: N2 @
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);2 h5 s4 }" p# z* j, B- |, K- `/ F
DDEDisconnect(kanal);
* v+ C  w1 |! X系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。  H6 E& u& g) c7 W
; Y9 M9 n' ?$ O- R8 z2 ]* u
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
- P. l' T$ J: J$ l( P1 K
" P" y  }. i0 g! E% z# P+ b9 y* M! w4 |; W4 h* [2 ~  J
木有人理我么?
% [: V+ e+ x& d  I3 Z5 ~% R5 Q
- I- q  o) q0 i  O1 a6 n: C- }" S# A我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:& |  S: d" f% D* W
$ z- X: [5 W1 p8 S1 ]
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);! W  Z& Z3 d" H# U' |# A& M7 b

$ s( b5 z* m) @& y* A但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
2 G7 J# k; P1 a% ]! p6 W: V3 ]( Sdde确实没用过,不过之前用过其它接口,不知道有没有共性。# P% n. U8 c7 O
7 x4 }. r) P# {6 d8 i9 ^
触发语句是这样写的execute("        'cost'   ...

. c$ r3 q3 q2 G% q! ^& L  [# J, ?谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
( w, A% H6 Y+ d3 [4 k% h4 M3 j
taoyifei2000 发表于 2012-3-29 21:37
4 T' [- [2 i7 y- Sdde确实没用过,不过之前用过其它接口,不知道有没有共性。3 w$ ^; d# w' l$ }9 O

' T; T$ p* X/ s4 a7 z" D触发语句是这样写的execute("        'cost'   ...

9 v+ p. H8 l+ Q# O4 ^/ X
5 [. K5 L8 f' j+ p& b5 t不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。+ f, Q- d! k$ T- v- w' R
2 `7 K0 T& z/ c/ r+ B2 n& I  |$ I! q
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 ( X; E  B" W! r/ V1 q* v. z9 R
若叶繁茂 发表于 2012-3-29 22:03 " _# X$ h* _5 r+ T) m3 l' E
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
$ W  j+ y4 R3 T- c( V4 c
* e! o7 g$ i: V0 ^* @* f+ 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 % z1 B! Z1 d" `3 W
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
% F' h. V$ D' P, A4 Z9 C9 ?
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。: ]6 p" t/ s! n, W9 x" V5 \$ L* t
6 e' Z! \: v5 ~8 \9 G1 t7 G2 e& b. ]
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
& Z2 ~8 t6 A7 n* T0 z9 o: U按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
$ ^$ }: }% }3 F* i1 K) ^( cis
, _, a* b9 @* Z        xl: any;
/ f4 U" }% w! Ldo" M; l- U! E1 y" a6 K/ `7 ]/ \
        if ActiveX.active then& l+ _& G/ K1 A, i
                xl:= activex.application;; W+ a8 w) c* Q5 \
                xl.call ("Macro_Reset");
, U. \* c, a3 E                activex.active:= false;
: u# M7 c+ ~" _8 @6 y8 |. Y        end;
7 F5 C: t/ a9 x0 W7 f) Q          |; L; r2 Q1 t+ u
end;1 p* E) n% T- w3 C) L6 F0 {$ o+ p; e

) G1 u- M$ t" m1 z3 J* ^8 B显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
) u# B1 r: b% Q0 v/ |5 j1 B5 N4 P$ A6 R9 ?6 z1 S* ]
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-2-19 06:41 , Processed in 0.013386 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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