设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 3348|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
+ X  V2 k; u  t* Nkanal:= DDEConnect("Excel", "Cost");
  ^/ l* |# a( M8 T* X9 KDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);* J' ]0 G& m/ a; c2 A1 F1 j7 g+ [/ {
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
+ G- f+ R  }0 Y2 k, U6 k. [' L2 dDDEDisconnect(kanal);" \# M2 }5 z6 i! Y1 S
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
- d1 @- Y1 h, c2 S& U+ P; y
$ f4 F0 S# C, C3 ?6 j$ v9 T请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 + P6 j  O- v6 c, b/ t5 _0 ^
: h4 @" V1 i: y- b, i3 U

, G& a6 b7 n% \) _# U/ ]木有人理我么?
. O4 [! W) S% I
) v; v; \( z3 h. x. m6 Q我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:$ M- n6 m. v( q& c
# \8 N- ^& ^6 m. G
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
$ S2 O& x: @+ x% ^, M. k9 V! P4 V2 z$ T
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37   B* y7 ^4 }- z. ^
dde确实没用过,不过之前用过其它接口,不知道有没有共性。: T9 e* s9 N4 k- _

, i% l7 V# V# r% E" E触发语句是这样写的execute("        'cost'   ...
9 W5 O  b" ^. y3 {* \1 h
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 ' P+ o% w8 A" q% D
taoyifei2000 发表于 2012-3-29 21:37
* M0 w8 m4 B$ h! kdde确实没用过,不过之前用过其它接口,不知道有没有共性。* B4 N6 M! e& u5 H2 ]% `$ C# e; N
% q4 Q- Q9 J0 o# C' G8 t3 _( N' f+ S2 z
触发语句是这样写的execute("        'cost'   ...

6 S$ T7 T, H5 I6 r/ S7 |! G* B$ C8 H) Q0 Z
' S; K) `2 I% M不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。1 Q1 W9 }9 @& \" f4 v, U; m9 z

. E, A% ^0 b3 r9 F' D诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
* ^) ?- v  [9 c% V9 |
若叶繁茂 发表于 2012-3-29 22:03 ) ^" Y; e( N9 u( `
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
3 p( `7 U: I1 {+ X  @5 ?; I2 W

7 k  l$ \! m1 R' h0 k我也没用过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 9 `$ L6 x1 j; i$ U: r
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
7 P- ~$ g8 o- R" s
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。" ~8 g6 b" d) H) Y3 q2 h
( v  P7 _" [. W2 V8 K  ?
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。5 C3 J2 F: U0 G' b% v; k
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
) q5 B+ y+ t$ \+ P1 P# {is
( _4 W* x# B: w! H# Q6 t* |& r        xl: any;
  D& ]7 m/ h% B6 [, M9 Hdo, _4 E# c5 |8 i$ M3 j8 N
        if ActiveX.active then
$ @1 S" b/ e" e7 j                xl:= activex.application;
/ s2 I7 e; w  }                xl.call ("Macro_Reset");
8 L0 Y0 c: k0 S' @                activex.active:= false;. i  X) n. c# k: Z# A
        end;  p. i+ c% @( v0 U: `8 L' L
        / N2 A3 {# ?! G1 X( _; x. u" {
end;
. s) u$ y: S7 w* C
5 P- i0 q7 @+ L' ]1 B, F显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~9 k; F( I$ F" Q% ]* o

- |8 R6 {( k0 |期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-6-29 08:12 , Processed in 0.016397 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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