设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4354|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:3 r# k" q" P8 _+ n: k! P) @
kanal:= DDEConnect("Excel", "Cost");, e! y( h  Q1 f! w2 Y+ ]
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);' z. z* T: w  R( n
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);& L  g" j* i7 r
DDEDisconnect(kanal);/ m( U% N% G, A# a7 d  R
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。1 z6 F8 |0 m% b8 N
) J" _! I5 i  K0 e2 g
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 ) |# T% v9 _2 O  b; a( B) g
7 M: A& O. @) E( `+ S! N. ]
' g0 j9 r$ n3 c8 n5 f. U
木有人理我么?
7 ]2 \! W4 G) @' D) i7 w7 x
  k4 g1 f" B( Q* L7 w5 Q我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:$ C4 I' c" G- }
) O7 o  B) r+ j$ n9 @: v/ s
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
5 E7 l- q' I5 _8 Q+ b  i6 |( ^; T. Z6 J# {7 G, _: Z: k
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 $ h+ s: x5 W$ ^
dde确实没用过,不过之前用过其它接口,不知道有没有共性。9 A  p' D  p3 `  U
+ E' f+ q4 H& W, s/ g
触发语句是这样写的execute("        'cost'   ...

! Y; a5 m% r0 W& e$ K* a1 C5 G) o谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 . F) }- {5 i; v# y, W
taoyifei2000 发表于 2012-3-29 21:37
3 _: n" s' o7 e- s( \dde确实没用过,不过之前用过其它接口,不知道有没有共性。
: r# l& o8 D0 g1 k' F1 `
" G7 Y" R1 C. a5 D6 b' G触发语句是这样写的execute("        'cost'   ...
' Q# d7 B6 u' r

0 J. r$ G1 g) V3 q; O- N不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
# Q0 q) `6 Q: {" ^1 H+ \) w( ]+ R4 G; B; k5 W4 u/ e, R
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
9 c0 T/ J! @, [, v! y! q. H* w
若叶繁茂 发表于 2012-3-29 22:03
3 i9 F. y9 Z3 P5 Y1 o3 [* x不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

% u" h. d1 T1 V6 @' I6 F! |0 U4 f  l0 E
我也没用过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
, G5 C4 ]+ T" p% j我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

% ~) T' A* m: A' T2 `! p( x谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
/ c  |( R& p- P" L: P9 I; i* o) G1 M
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
. v  A4 O+ B2 P8 s按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
  |8 Z. p7 _; Y  o4 m3 \is
; b8 i6 o% D& u! Y/ o& ~' |' [; T        xl: any;# C9 M! D% E3 L% B
do) Q8 f0 B/ d5 v' [7 e
        if ActiveX.active then
* i. b) J' k, }* M1 O2 ]1 ?                xl:= activex.application;
$ w, l( [0 c+ l8 m) M                xl.call ("Macro_Reset");1 h$ E4 K$ r3 `* E! z. ?* v9 y7 y
                activex.active:= false;' E# Y" s3 E8 C, P& c& i5 s" W
        end;
$ ]) p. ?) A3 Q: W' p        ; S8 s* H" F# I  V! s
end;
% ~2 Z$ L2 |7 f9 j: ~5 ^" s! c0 \/ Y' M' M' f1 n$ j; {9 w; I
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~2 z; g- g6 K9 j. X! E

' D6 y  Z2 r% }6 F4 L期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-8-28 23:24 , Processed in 0.014862 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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