设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4397|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:8 L0 B* L  W7 ?2 c( s
kanal:= DDEConnect("Excel", "Cost");: `# @7 ?# A- y+ p
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
$ k3 d: V6 J% K" Y( P5 y$ WDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);8 d$ e0 u/ o8 i! C
DDEDisconnect(kanal);
6 z% Z% U4 U5 d系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
5 j  T3 H9 s. }7 o  y: ]) f( P0 n! U0 m5 ^0 K8 ]3 u
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
6 }. F( t% e! N- \3 K+ h; w8 H& w. s% ]; h6 o- n  T
( p/ O4 B2 A5 B" |
木有人理我么?
4 }- ^5 G8 @$ I% A" o, g! }- d5 {
8 _6 O. g# J9 K$ E我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:) ]3 s5 o+ _* q9 W5 G; ?2 U
; ~3 B" `  J4 e9 ~: V' Q5 x
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);# i7 y$ q0 S  W

, b$ ]; `# S" p但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 $ R' W  x! [% K; y) J, M" y
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
0 t2 s. L% x  c  O9 c
& `! v. B3 }9 Z8 m9 I, z+ M触发语句是这样写的execute("        'cost'   ...
+ A0 \: d- W5 m7 N2 o
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 & Z3 B$ A* |( j
taoyifei2000 发表于 2012-3-29 21:37 / l% E, d2 T, F+ Y
dde确实没用过,不过之前用过其它接口,不知道有没有共性。+ B9 l) d+ K( K4 t' v

2 j- K0 [) j7 s& {触发语句是这样写的execute("        'cost'   ...
9 Y5 b' y1 s1 j
7 o! h9 I7 ]$ D' d! t2 K- o
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。( C& F& L' [5 E6 a

/ ^0 u- J2 Y6 s诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 " G0 P6 }: `5 `) j
若叶繁茂 发表于 2012-3-29 22:03
) a: G! i( ?# D( F: [8 s! y不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

" c! K3 P) x5 m# O( h, o+ j
  s7 ?- `$ z  ~9 `& b; S我也没用过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 e# P( G- d) }我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

; @; I6 v1 ?* c& E谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
: t9 Z+ Y! r. e% x1 s* M  X; a' E- ?: N' Z+ t
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。. z- ^( l' l2 T6 B8 t. @
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:6 [# a. v$ ?& T1 v; a1 }+ Q' A
is4 D$ B5 Q: s7 K
        xl: any;
; k8 b% z; W3 K0 \+ |do$ S! ^: _& ]% ?
        if ActiveX.active then) f& ~# L+ I9 r4 _# _4 b
                xl:= activex.application;6 h- [' y# H: J, x8 j
                xl.call ("Macro_Reset");! `4 l( F$ \! B3 X+ z2 p& O; X
                activex.active:= false;/ P, `4 q6 b0 i& X
        end;
- j% m$ e* c  N1 x% O; v        - N- o! v9 l5 ]/ w. ~" q
end;) l+ o0 k! ?1 b% q4 `

( [3 Y) p0 N/ T4 b& i; }& q显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
/ ]" h( S* H* f% v1 r7 h6 }6 H8 ^$ v9 M, H! @7 \1 N
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-10 19:02 , Processed in 0.013468 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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