设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4151|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
, {) X( M8 J, T  u  b- d/ _kanal:= DDEConnect("Excel", "Cost");7 q4 [/ m& q0 V
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);$ m. ~$ Z# L: B  D
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);" B/ ~  s  W9 X2 t/ A5 y
DDEDisconnect(kanal);, \5 b! o$ Y5 d) Z$ T9 Y+ A; Z
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。3 G9 r' _2 Q/ |1 q5 i+ Z( k

1 s  J) C, g' A请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 4 W6 l/ i' @0 q! ?" {+ E0 k
8 ^- |' R+ Z' I: ~& M% V8 q
' N: n: J- [, w4 w* y
木有人理我么?
3 B* a2 ^# F; G, X: k, S. K0 k
- D& r& s' N) P/ e我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:3 ?0 ?/ `7 @1 V" J- Y

6 g& c5 r0 p$ v  C# U) @; oDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
1 F9 [) G2 f) x" a1 U
9 _% F# C5 b/ S0 ?' S, }  ^但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
) M9 q& T* F$ ], Gdde确实没用过,不过之前用过其它接口,不知道有没有共性。: z; T1 D8 h$ R6 e& m
+ i, {- W- h% s) l" [2 Z% a
触发语句是这样写的execute("        'cost'   ...
- `6 H' C! Q& _
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 " ?2 a7 G; q6 v; k
taoyifei2000 发表于 2012-3-29 21:37
# ^# o# ?$ d! G" `: D1 vdde确实没用过,不过之前用过其它接口,不知道有没有共性。
$ \" N; R+ @- a) Q! J: r
2 X; ?+ g" \1 I$ h  n$ l9 G  l' q触发语句是这样写的execute("        'cost'   ...
" c4 d! M, e$ c$ Z3 h

! I; f: _4 y6 j不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。' B- `9 |/ z% z3 d% d
) d. d2 T0 a/ K  O9 l
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
: x. D  @7 v( ^, j, I( R
若叶繁茂 发表于 2012-3-29 22:03
" {$ B/ ?  [; n- r% Y8 O! H( _* b不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

7 [6 o/ _; P# L3 T& r
9 H% k5 ]' j; n; M. V- D* B: S2 i9 j3 t我也没用过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
' l+ }. b5 S/ M我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
6 ]: Q7 m7 g' \3 A5 G* o9 s
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
+ b/ s- y& X4 S: I& X- s; s% B3 x7 ]3 C9 W+ g
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。- y+ d' d% W4 `+ C* j
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
8 y' r& u. t% l/ Jis% O/ H6 s) n5 B$ H' ?* {
        xl: any;
6 r. \6 t1 @' Z4 C- e) e  \do
6 W  a+ s, T3 N" |  {# ^        if ActiveX.active then
# a4 b" J: M' g! _6 }                xl:= activex.application;
2 m& j  X4 Z) I' B2 [6 x4 r                xl.call ("Macro_Reset");4 Q$ T/ i2 B+ R% W
                activex.active:= false;
( c0 L. |1 u( H! \' [7 U! W# I        end;
. i; _( X5 b+ b        - i6 g% S! d, S
end;4 ]3 N- p) G; y- m% t! Q4 B8 D7 ]( c  w

: ~) N7 Y' k4 k显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
+ H  R$ \0 Y( y+ V
! Z3 O( G" g3 F期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-6-30 08:01 , Processed in 0.014630 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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