设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4742|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
5 {0 z; W& X/ _9 tkanal:= DDEConnect("Excel", "Cost");
% W% ~$ B) c. |% ~- ~4 f" i! RDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);2 o3 L* N4 s- o0 L2 C: Q  I3 @
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
8 }- Q! L8 b: z* x9 UDDEDisconnect(kanal);; n0 E2 J- ?% z
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。( o: v8 ^% J9 v4 R& S0 W

6 U9 z8 @. |. m8 @  w8 t7 Y3 z请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
. @7 `7 \1 M" O- b7 C* g& |5 _8 s" o) p, _
; E% ^' V/ i. |# D0 G% Z  d
木有人理我么?3 _: V1 @  @* q7 S1 f

+ k7 g$ E. S. D0 a我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:  O1 d) l. W1 L5 b8 g& }

& K& {5 X0 ~. mDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);2 ^! s! q2 L  f  u% ]

, W( x' a8 g+ |. {% ^, i但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
4 C2 }' a$ J$ j4 m9 Z; g. Mdde确实没用过,不过之前用过其它接口,不知道有没有共性。
. `! y1 e! F9 i7 m
' r0 Q& U. t, U( x触发语句是这样写的execute("        'cost'   ...

4 c; b9 t  L& s9 {0 J" f# K3 X, T谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
2 _0 [. H; W' q* _0 o) o! Z, u
taoyifei2000 发表于 2012-3-29 21:37 ; D- r& f0 U- ~1 m, ]# R3 y2 q4 v/ L8 i- S
dde确实没用过,不过之前用过其它接口,不知道有没有共性。- Z1 D  z  k# s
/ O- F8 Y. h6 h
触发语句是这样写的execute("        'cost'   ...
8 C/ j6 M) B' v6 f

0 ~: Q& [0 s& a8 u/ [不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
: h2 X6 O, b9 @) B& z% t7 k  p' v3 z- y/ J
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 ; I" `/ y) I) W* S$ X# Z; X3 f( o
若叶繁茂 发表于 2012-3-29 22:03 ) Q4 m% [8 L1 }0 G$ |
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

+ t, Q( U1 J. k6 N$ V
+ _% M7 z. g+ E2 ~: [8 S9 X9 j% z我也没用过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 ; @/ {2 ~$ ^2 q; e$ {- i5 b  k
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
# G3 {* V5 V* V4 \
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
  w' b/ e+ y) u' R; ]2 |
. h2 e. [% H5 D我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
' {5 ?% }2 Q  T/ K; F  g) u按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:% f8 C/ t. d* Y% n: l+ }9 ?( Y  o
is2 W8 x; L1 g$ @* v! B& [
        xl: any;
) g; q, Z! V& k# m' b) _' X  ?* H) Udo
/ I6 I& k1 b* g/ S/ x" y0 o# i        if ActiveX.active then
. ~  U  q) m& a* e                xl:= activex.application;: r2 b1 b  m/ v$ C* `' r; M$ c  P
                xl.call ("Macro_Reset");6 G  ]8 l! w: K: V) I4 `! O
                activex.active:= false;
! z0 \& z/ ]6 o  u2 g. G+ _* y8 N        end;7 B  ]2 c  j5 L$ ]2 h. I" |; u
        ' t, K+ v5 j; x$ H
end;
* n7 v% e# y: x6 d+ a7 Y) J+ v$ t. d
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~8 H" w7 L; _: I' h
5 d$ z/ V. P1 p3 _1 f% U
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-11-6 03:52 , Processed in 0.015522 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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