设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5510|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:7 G& U, Y7 i7 Z9 S$ k! w
kanal:= DDEConnect("Excel", "Cost");8 o1 A! t4 E2 [1 i) e% J. z
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
0 O3 X; |) o! K0 G0 eDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);7 M' L- D: ]( U1 y9 n$ I' J
DDEDisconnect(kanal);
' p9 {5 r! L8 K; _! j- G$ }! c系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。' @0 j# K" H7 k$ J

9 |( l& W: e/ m2 K3 N& Q5 v请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
4 Y& q5 n/ w/ r8 b) ^2 H: d
6 A; V5 G" e  Y( T: s1 M" k0 k2 g% S( `$ u3 g# \% t
木有人理我么?* F! L& D. w5 z+ I. t
: D- Q' S8 S" V$ s
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:" g1 s3 l- l" A9 d
4 K- g5 x' m$ z; a9 x6 b
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
, p8 C: [: b# p7 E& ?
5 X  G, \9 x* J* L5 ]# ^  f但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
* V. T$ P  |% a6 F& J# R2 M) ^  `dde确实没用过,不过之前用过其它接口,不知道有没有共性。
9 f8 e3 T7 y1 ?& C7 p4 J) n; O3 o; I& `* E, u0 i4 L! m
触发语句是这样写的execute("        'cost'   ...
0 @) U  n7 u! ^4 D/ p) e
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
3 o8 a& B/ q, s' @( O( n1 {
taoyifei2000 发表于 2012-3-29 21:37
+ x  d' L' g  T+ E0 zdde确实没用过,不过之前用过其它接口,不知道有没有共性。6 d6 k7 ?5 V  N: A$ Y
, Q! S. T: }& V0 N. D5 k
触发语句是这样写的execute("        'cost'   ...
/ D4 s5 @. }3 P
7 x; Q# s' }1 L3 g
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
$ w' n1 y& W0 q2 D. q  K9 `) R
. `& _$ C/ W" H诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 4 N7 D1 N" @5 b6 }  O
若叶繁茂 发表于 2012-3-29 22:03 ( U  e0 q5 ]1 R: A& v
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
' Y& u9 E! R) d' G$ Y; l' U5 U

) o% I0 Z' [! M' I* Q3 y2 x我也没用过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 9 H: t0 z4 i% y' B/ a& t. t
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
7 r, N- E" ]' `/ h) k: G
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。# d+ r# \/ r  a) D% s& N: z

, P: k9 |  `* Z我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。& p1 ~5 G& u- T& Y
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:# }  W8 U" \. K: G# V
is
, o9 y" K3 \7 V; ^* n! o/ J' v: X+ J* r        xl: any;, F- u) }( Q8 z2 }4 D% p: y/ f
do' P2 l- o$ H5 }) g/ T4 \
        if ActiveX.active then, O( Z, h3 p) R% t; R1 ?
                xl:= activex.application;
9 I. E! O$ A4 B0 p; G                xl.call ("Macro_Reset");5 z7 n0 P% }9 X
                activex.active:= false;& M4 v3 I7 k) [" i! E7 j: ~. R
        end;+ v5 P7 u  P/ x  t2 ]" \4 Q, t$ B2 E
       
% n- f; K: N6 Oend;
. a: Z2 N, k% }* q) M  C) z. F6 J. z1 a
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~( d4 X1 M/ p1 D0 W6 \

9 t1 U: B8 M) n8 S3 D6 k期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-21 19:51 , Processed in 0.012256 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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