设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4355|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:- [6 D  v7 \  O/ A/ S
kanal:= DDEConnect("Excel", "Cost");
) j+ P1 [3 r4 n7 |/ xDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);- O; n/ z; G( j+ {4 w: V/ k; v
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);8 O9 j7 W' D1 a3 f, G0 R
DDEDisconnect(kanal);
3 N4 ?( N- w8 F( {0 m4 Q系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。6 `% @4 f5 p' ?' F& v
: x; p9 s& j8 V" y$ h
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 . i% |: S$ O- ], x4 K6 f  U3 R
  A5 j  k) T( S
3 K9 {9 S2 X) j8 t
木有人理我么?$ r" m+ p9 i% Q& n: T
- i, }+ B8 m2 b, P4 x1 x9 q1 p
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
/ v: p7 w5 {, t8 E/ W/ G
2 Q; w/ r- ]0 u3 M' EDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);6 H5 H  o5 H& [% p  Z! M

/ B' w) |, E! l# S3 U: L但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 1 J+ u: v9 r7 I" u+ `. B% Z& z
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
0 I1 S0 Y& `- F
# w4 b2 ^& j+ `6 S/ O9 |触发语句是这样写的execute("        'cost'   ...

. F# _) \( |7 d) R  K0 U谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
+ d5 v, C" Q5 d/ H9 l$ V0 W$ V
taoyifei2000 发表于 2012-3-29 21:37 0 d7 [; G: I& Q+ F& t" S8 m0 w2 p
dde确实没用过,不过之前用过其它接口,不知道有没有共性。$ @+ ?! w) z& V6 N
# Q' n2 P" e) {* _9 J' V
触发语句是这样写的execute("        'cost'   ...

- P* O3 n6 }8 b$ e1 S7 G1 ]. t1 b/ z
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
& X9 T+ }  Z( h4 [5 A! p9 ^% i4 ~& d" f% h2 T" \0 B1 v
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
  Z3 Y% w1 ]" O0 H0 \
若叶繁茂 发表于 2012-3-29 22:03
2 i# P8 [5 m' R2 j不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

# |+ z0 }; H) b6 V& W
6 k% `2 ]1 Y$ T- _3 y8 g我也没用过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 ]3 D) z7 X/ {3 Q, S9 R
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

" G$ g& u3 }2 w" @$ N# x$ L谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。: M2 B5 ^( L% t9 i& w3 O
9 C& k' e  V% w
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。4 P) }& n/ e9 P: l4 a
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:" d  a6 H- e( E5 g0 d
is
/ ^% P) C: e: g3 A/ ?" j9 R0 M        xl: any;
& _, d9 w% M' F* q, ]( mdo9 J) O& ~* F# Z- @, o
        if ActiveX.active then
4 X5 H9 e  S2 |! i                xl:= activex.application;3 i' V' e0 @9 u5 j$ |( c+ h0 m
                xl.call ("Macro_Reset");
' @. [0 `+ J0 j& @" O8 ?' s! h                activex.active:= false;
% Q5 _+ f% n, X        end;3 ]* H& t; X! K6 k
       
( ?" H' |6 _6 w  Lend;
+ Z& |) m# G' R4 X% B; Y' \' g  ?( _1 V3 `* F
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~1 j* c) d5 ?# r- h; }
0 V/ s3 ^/ n# }& Z$ J9 R$ H
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-8-29 01:27 , Processed in 0.015392 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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