设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4967|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
2 W+ D! V8 s& Q. c& l! |5 I4 a5 akanal:= DDEConnect("Excel", "Cost");
) S# u8 x$ k% `8 q1 ^DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);/ w, x5 ^6 B6 ^. q
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);/ i* P' X9 A( w& Z, v
DDEDisconnect(kanal);
/ s! g. `/ S0 ^系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
- V& ?) ?7 Y+ p& p( E0 I" j: A* u. i* Z% u
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 5 ~6 E% g6 e& P9 W9 ]6 Y) T: Z# P4 g

5 x1 o: r- H( @+ z& B
1 k4 {1 w; Q+ E; D" }$ {/ n木有人理我么?# j& h/ a3 A0 P+ E6 i5 s, `
7 l7 t& m3 a, `2 W
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
0 f( q+ g6 g) V3 Q! r
1 e  G0 `& k; K2 Q6 t( SDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
7 A# l7 E* F! {3 i
3 h4 W; A( Z" z: m4 |  _但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 8 V- C1 ]7 C5 v
dde确实没用过,不过之前用过其它接口,不知道有没有共性。- V1 h4 Q# u8 [' |2 I

$ e: j- }' U' P触发语句是这样写的execute("        'cost'   ...

+ E, g" ^* G" d& d0 X% b谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 0 Z8 w  u( D! T" @* d6 [" P
taoyifei2000 发表于 2012-3-29 21:37 ' x0 Y% l: x6 K( z' ?
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
. ~% J6 u, [/ Y, a* q1 J1 e# D& E" u# T1 j" g& d
触发语句是这样写的execute("        'cost'   ...

1 b# `* e$ l6 b+ Q' z; a, p8 P: I* S* M1 [
7 {4 X0 p9 B0 E# t; m/ Y不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
; Y* _5 ^) ?/ n5 p+ d2 k* {) _% [
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 ( C: Z6 k4 @  R1 [9 ]
若叶繁茂 发表于 2012-3-29 22:03 ; k# v- Q* j9 L" s8 T
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
4 U: f3 V- V" `  _8 P

$ b7 M# r( j* M( t( D我也没用过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 8 Y8 b. @% T9 _1 e! `# J9 g! d3 m
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
, \. n* I' @- `2 D3 }. p! P
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。: z8 q% }) d5 U8 x6 T& W% m
. X* k9 U; n2 R* D6 j+ _
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。9 z8 q2 Q; I7 v
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
, }! g) H4 V1 lis6 ~! B( O: z: o7 }+ m
        xl: any;
2 Z5 h% J: n# U5 A2 P. ndo" R! x4 S- ]) u; P' E( |) s
        if ActiveX.active then
$ b+ ?' i. h7 S2 p$ c: m                xl:= activex.application;) J# @6 m9 p& ?+ u. s! U$ h: b
                xl.call ("Macro_Reset");
: M! F0 B; I7 P9 c4 l1 e                activex.active:= false;) L5 u- m+ G3 H8 m/ Z/ h
        end;5 \  N. L4 X. h: o6 N, ]
        ) [9 V3 C8 _6 x* x
end;
/ i: \# z& c2 j/ L* p2 @7 G- D5 a6 J4 f: H- @6 X$ W' H8 P
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
/ d% ]. ]/ e4 V0 @- B! w
: U1 v& G6 B' T. ~期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-12-19 02:03 , Processed in 0.015762 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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