设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4309|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
( `0 V# T: R( y3 d& }& Nkanal:= DDEConnect("Excel", "Cost");
' t" t. B) f9 `4 r# G/ g9 {1 g  SDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);% ^+ |& Q* k. |5 A2 D. y) P
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
7 z( u0 l$ B/ NDDEDisconnect(kanal);
& {  z, ~; j( u$ Y! W+ {系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。2 [* S9 C  h( ]2 d

4 B: m+ S5 i; h6 H: H& ^# L2 R请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 ) U( n1 p9 F( u. t  F: `

5 K+ u; F0 D( x1 p
  G- `; D5 G6 K/ B木有人理我么?% g. }5 Z3 `9 Q0 D+ R

1 w6 M( X/ m: t. u4 B我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:- Z; W' }0 t. b, A

) w. w! M2 z6 i# o% o& \8 {: nDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
; h$ L' m0 K3 |& K, s% ^" q* B  R3 z/ ]
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 7 v7 K, k& r  o, |" d
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
  [% a4 @; g; E3 b4 F  o$ i. @  i" o
触发语句是这样写的execute("        'cost'   ...
% x& W% Z/ b; h2 l
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
: l6 e. J, @& @) w* m# Q
taoyifei2000 发表于 2012-3-29 21:37
6 Q( A) y3 t" O: |% O/ X( F, c4 Kdde确实没用过,不过之前用过其它接口,不知道有没有共性。
! k0 P9 ^( I; p4 P$ y5 V9 C& C+ v0 K
触发语句是这样写的execute("        'cost'   ...

4 o& g& W! C7 _  J. g- S7 L, I6 N2 ?
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
+ c$ {# C/ K8 t7 D
; V8 `: `) ]- {诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 7 b0 N7 ?* ]3 a* P8 W8 i
若叶繁茂 发表于 2012-3-29 22:03
0 G( y: V$ [$ J7 l不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

: Y& S$ ~% r* s6 K% d) M5 S: \$ c9 i& r+ o0 a
我也没用过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
3 t& P4 {* ^4 V$ D我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
' [. ~, X; U% K, v. h
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。9 F( S- g+ A+ W
. m1 b( j% D7 n1 H* y* P" n
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
+ @- t4 ~/ s) ~( u, W  k, H按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:2 ^$ a. b8 I4 _! r& J
is
" b. y5 ?, k  B7 B        xl: any;
( m+ K! G8 X: Z0 @- @& r/ ]. q, [; [do
& F2 `* ^/ X6 D        if ActiveX.active then6 p1 c* Q4 G8 n1 `1 r( D% O
                xl:= activex.application;
6 v" t: v9 [( O4 o1 e1 N8 `  T                xl.call ("Macro_Reset");
/ D" V9 g+ `9 S1 D% [                activex.active:= false;# p5 p& N0 O( _
        end;
# Y) Q* s% X  \/ f: {- s: A        / p0 ]0 Z* U9 k1 Z$ |: z, J8 P4 P
end;% R4 B, z$ M+ g! A

- d3 ?. T6 z$ N: h显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
( o6 J6 m  _% I: c& d  z/ s6 P3 y" e0 a3 t
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-8-22 00:53 , Processed in 0.014553 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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