设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5386|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:# Z+ {' R, e8 x5 ~
kanal:= DDEConnect("Excel", "Cost");
) x- z/ Z; t" L3 p( {, C' P5 QDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);. b6 h; y4 h3 m% y
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
1 q3 K7 ~  ~- S  c2 o8 [! d/ _DDEDisconnect(kanal);
. l" x$ B, S  A: j( l" w/ F系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
/ ?4 F0 `, O. k; G1 e9 D% W' ]0 e' }$ ?9 ?+ C  t/ E
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
  U3 k& g# l6 l/ U, }( R8 M
" p$ g5 d' {, E2 ]# F4 \7 L& J/ k' g, p
木有人理我么?! N' F9 Q1 P8 O% G
0 j2 L8 W7 v$ V2 q$ c/ @. {! j
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
" C3 i$ I: z- i% c+ ^) K2 M9 W# U
8 F+ ^7 }7 C2 I$ F) G2 C3 o! MDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);6 N( _& n4 u5 v
! Z; }2 e2 N) W$ D& m% X
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 8 u! B# f1 r5 S
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
; l' J6 J3 m: h5 u  z$ D" M0 F3 P# \/ [% t7 c1 ?
触发语句是这样写的execute("        'cost'   ...

4 ~8 A& @" J' u谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 $ D# Q* P; r5 S& G5 q2 h
taoyifei2000 发表于 2012-3-29 21:37 ' c4 {8 o) ^9 y0 i+ H& o& }6 D
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
* t( k" q$ g: F# }+ {3 e9 ]5 G; K
9 g- G; j. Y5 K$ s. z" @+ A, E触发语句是这样写的execute("        'cost'   ...

5 b) h. k8 \5 G0 I
) b4 h. d  K0 ~) U不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
4 _! t" p6 ^8 _: a# z7 E5 ^  N7 ]3 j7 ~
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
( d" Y4 j! _1 G7 y
若叶繁茂 发表于 2012-3-29 22:03
8 b) G" u6 H$ z# }( N# P9 \+ }不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

: n" m0 u# p  F5 e
* w- r8 s$ o! W  z8 ?! D" b) ?我也没用过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
- M* m! K6 t5 J9 I0 |6 o1 z我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

6 P+ h* Y* c$ D谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
( |3 {: T8 a, {1 J' d# j
3 r: y! v) C, [我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
! x: ]2 m8 s' G1 Z/ U4 C& p* b按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:3 _' F; f/ f5 x& S2 k
is; a8 `1 g5 j* l% f' s/ \9 X1 A
        xl: any;: a% b* v) A2 s4 c% P( t
do9 {0 L& w9 j/ _
        if ActiveX.active then, ^# o& e' B, O. E& c4 G
                xl:= activex.application;) N  b' u8 K6 l) p2 z
                xl.call ("Macro_Reset");
9 A) `/ h$ i& {( K% r  r7 N                activex.active:= false;% ?; n% H& t6 Z, m
        end;
) e* U8 Q* t  }/ S% W9 {       
0 Z/ h+ m1 q- |4 c- W2 {- i0 send;! _) N$ N% k/ E' ?! w& r6 ^, e- e

$ n2 x, C; |/ a  O显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~% O$ E& E4 U% z$ z3 S
1 M, L6 [/ V6 ?: I, @) P$ `2 F
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-4-29 23:40 , Processed in 0.018239 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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