设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4744|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:. @3 }4 M3 @2 @" \" N' M3 y: s" O
kanal:= DDEConnect("Excel", "Cost");$ n, x+ C4 z9 ~. b/ h6 g% n4 h8 f
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
* N5 n! @% T, L! X+ MDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);: M# h& j6 L( \' O# T0 [% Z
DDEDisconnect(kanal);4 G. ]0 c$ y$ z- J
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
# e* @- f1 d8 I1 m9 D! P
, J0 |) u- @( C3 k0 j6 x& J! j请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
, i) P* ?+ o1 K4 R
& f  ?" _* z+ p( R8 H5 j4 [1 ~! h3 ^
, j9 s# e5 f7 @) z- n3 X+ t木有人理我么?
( ]2 t2 \. L4 f- n" Q5 r$ l2 \
3 b: j7 B8 p% W+ i$ m我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
3 {# o6 s0 o# m9 m. i3 m+ ~6 f: L9 z, U' R+ a- g7 Y% V- m' p: X1 b
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
+ Y4 `, b/ C5 v) `% \9 h8 ]& |1 _5 R) ~+ o+ W
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
0 N' v1 I; V. t4 o$ W: ndde确实没用过,不过之前用过其它接口,不知道有没有共性。
( o5 X0 U& G4 A, Y! o/ U! n  u$ I$ S% v3 ~; K: }* y* e* m2 g: G
触发语句是这样写的execute("        'cost'   ...
6 u" y3 d; g# Z
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
* M/ r6 p/ X# o$ t) v1 O) C7 m( l/ Q
taoyifei2000 发表于 2012-3-29 21:37
, H: h) U- L( x9 Jdde确实没用过,不过之前用过其它接口,不知道有没有共性。
; V: A. ~2 c, [/ E: I4 e2 T6 x0 j' _: ?( {9 [# f1 y5 ~' b6 n
触发语句是这样写的execute("        'cost'   ...
5 {3 ?% Z( x$ t+ K! t- E9 g- _5 H
3 A# X, G3 }# E5 u/ D
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
/ `) u$ ]/ h3 m4 W
- [0 S: A+ l: J8 |诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
1 I# B7 H6 `5 `# Z6 ?* J  u: H5 I
若叶繁茂 发表于 2012-3-29 22:03
2 n5 J" I# R5 j( _) ?不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

- d: p7 W- @* ?9 R( T) E; R9 \5 Z8 m; m6 p  h
我也没用过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 - v9 m  G- V7 O- B
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
# d5 x* ]5 r2 g% p5 ~
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。4 a6 y% p5 s! H7 L! s, Y9 `' m( [7 ^3 Z

0 W( E) r+ x  f' }# R- k7 d我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
5 r! e+ b: V0 F按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
2 r( v9 _$ ^3 eis
' y, K& S( R5 L2 A        xl: any;# _+ i1 X4 U/ |
do9 ~5 G1 Q3 }" m$ t& B, H
        if ActiveX.active then
4 g# a# \, d& R2 R                xl:= activex.application;$ \) z7 ?- [# }! Q0 L
                xl.call ("Macro_Reset");
9 }8 O3 [) O( F( v                activex.active:= false;
0 C0 O" g$ I4 R9 o        end;, h, ]/ B8 k; S& V% C1 P8 y! F
       
; m8 D) b6 t2 G! s$ aend;
6 _; f6 B( f/ s. K0 e; ]  S3 C' g* D3 x( s- L: E% d! k2 L( l& T
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~" Y' K0 e0 A( u

+ L, Y& s: O/ v& P% [" I期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-11-6 03:59 , Processed in 0.020609 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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