设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 3633|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:; c) }( ~5 V1 H6 J+ {4 J+ n
kanal:= DDEConnect("Excel", "Cost");
; Z! `  N9 _* h/ H, i; F/ A+ R1 QDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);. a4 B) G+ X, P/ X$ N! D7 V
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
( D' f7 f! Z4 B) D& i0 v* SDDEDisconnect(kanal);5 C- `+ l; O4 q, A
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。0 L+ U/ y  A6 t' X/ [! x! k. i
8 N) {/ ?3 W) u; ?1 U7 v  Z: o
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 ; ~2 L, e9 G9 Q( Z+ w6 Y1 e5 `

& ?. E9 W) E  ]: ]* V7 ]: m$ e0 t- W# x5 Q( a/ d. g" _, w
木有人理我么?
! ^) G+ h3 R2 C  B, X) ]/ X0 K: q5 i
4 l; e( F  t1 |( Q我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:" A& s% K) ?4 |' B6 o9 M

8 z7 `. R% q; Y* xDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
5 W  u* L; I% ^3 k6 {" r, s( {
3 ~- A& [! f' _+ \0 X! p但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
5 g' g* \5 Q- j# J2 bdde确实没用过,不过之前用过其它接口,不知道有没有共性。
0 U1 b$ O6 v4 _1 _$ ~4 I) V8 F" Z1 H  h0 O1 R/ o5 Q/ d4 b! G
触发语句是这样写的execute("        'cost'   ...

' _& Y% L; i, e4 O; [8 w谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
9 J1 J) {# @1 e) o5 `0 x
taoyifei2000 发表于 2012-3-29 21:37 / T4 L9 M2 }! z) ~  d4 _' v. x
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
* f# R  J" g2 a7 m6 A% I5 ]3 h& D" V0 c; L2 {
触发语句是这样写的execute("        'cost'   ...
3 w6 e; x5 ?! R/ `7 h/ |6 d

, t" X* A3 e, T+ J不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
* Y% U$ j8 V4 d8 m, X
; A4 T8 A% E' F. G; h诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
7 X/ M- h' l) I5 c. J  w
若叶繁茂 发表于 2012-3-29 22:03
# k2 x0 Y( s: ?: ^" B不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
1 h/ t! r+ A% ~! h5 Z
! J+ @: [% s& n# U
我也没用过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
: z; c- @+ u+ j. q* D+ K6 @我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
4 D% t2 i7 w& u  V. G
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
% u! U3 T! I7 U" _' m  A2 a' a
( u2 X5 w& d# n+ G% Q7 o  i" {我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。- H- G4 f& r* j9 `1 @' |! x" b
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:! m4 W7 d- {2 S$ r
is
7 \3 q: u4 l; z# q8 |) @8 u5 b1 W        xl: any;* P  b, g9 b+ z1 v5 B% X& J& s
do5 h/ [6 [  |8 \% N$ \9 ]
        if ActiveX.active then1 x/ v2 N' t1 ?# B
                xl:= activex.application;! A; e1 Z5 m2 F* C: X
                xl.call ("Macro_Reset");
7 M0 c" g) ?" @% q5 [) c. n% \                activex.active:= false;8 j5 ^/ U9 s$ t- P8 t
        end;9 M4 A" g$ K% J' j% a: Q
        5 a; t$ `/ R, g6 L' a$ _
end;
! H6 b% B3 E) v: M" ^) w6 Q, R5 f' n+ D1 U1 x" V
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
& U& _" w) I8 ~# f' H9 V" _- n# d6 i6 v, l' C" `( o$ X2 [0 N
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-1-23 05:56 , Processed in 3.570177 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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