设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4968|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:) }- O6 H& K  i( H  \: a9 g
kanal:= DDEConnect("Excel", "Cost");
. V# Q" S0 [! yDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);! K- P1 y* E+ h" P1 k- _
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
0 J# y9 O2 K' ^$ V* [0 Q* [% kDDEDisconnect(kanal);
$ F' @( ?3 c; |5 Z系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
4 j7 ^$ f% W) `4 R  c) v" c& i, K* F* ?0 D3 r# T- G
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 . {, a. l& L6 T: f7 V  K, Y

% Z: T( n. r1 q0 f" G8 s  S- _$ e! o
木有人理我么?
+ `: O( ~; {4 w3 w
% Q* R( X1 Y+ A. P我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:2 t3 v9 U% ?" |3 {
/ V: W2 k0 y1 L
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
9 ~4 x: Z8 Y) C3 S" b1 P. }* w# d  b" H, p3 {, U) b
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 ) a! @/ ~4 b! ^0 H/ P5 m
dde确实没用过,不过之前用过其它接口,不知道有没有共性。" M& W/ N6 F% \6 W- j! F. k

" ^- G3 }" Z' P3 G/ b: |触发语句是这样写的execute("        'cost'   ...

; d3 V5 D2 y5 M. P8 p. _1 R谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
) g  m2 X0 R2 l5 `+ M
taoyifei2000 发表于 2012-3-29 21:37 ! N8 U; h9 a  _9 \/ e" V  S
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
; N. i. p2 W$ a+ @( V+ W) y0 h/ H* ~  L6 Y, M$ F* N
触发语句是这样写的execute("        'cost'   ...
# J. V5 l8 C, }( B; D0 L! l4 w2 F* e

" y! h+ K" j0 r  ^0 N. w不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
( w6 z3 w' c; Z4 n, i
7 t; k2 ?' N5 S1 [. T  E8 {诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 . C# H" k9 t  h9 `
若叶繁茂 发表于 2012-3-29 22:03
: y2 m5 ^" {' W" K  _不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
) h$ `2 q6 p6 @4 M

' H8 Z# F8 J6 h& {* _) H( V; q我也没用过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
4 ~8 L) k9 O! x' W: a9 g我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

# C& V( k7 z& C  _" J谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。& W7 b  T) {, G% z

% m$ |8 B+ k6 |- i4 l我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。1 ]& A, n7 L- T
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
5 @) b! z8 e/ }- Y. vis
' y! \9 O5 i1 A. I. @8 Z7 F        xl: any;
2 D9 h# R' I# C. Y. bdo
, T2 [4 {9 |; G! o        if ActiveX.active then7 n6 P2 I4 t4 S& n' v; J$ K
                xl:= activex.application;+ b9 F4 }" |" z, W, F9 {6 F
                xl.call ("Macro_Reset");
: o. y, p2 W. {6 C6 N                activex.active:= false;
/ e. R" q( p2 w2 a# A3 X" _        end;: A8 A& n7 R  L: [
        6 v/ O( K' X0 e+ @+ ^2 ~
end;
$ n( r7 D% X9 Z% t
- W. Y* `2 M3 ]! E显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~" J% H( x3 P3 R0 R: P( _# P
) R5 G; N: S: L% J' D' S/ l$ H7 u
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-12-19 10:54 , Processed in 0.015728 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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