设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5419|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
; |% q$ I% b" l' p% {. Zkanal:= DDEConnect("Excel", "Cost");
/ e) c3 O. [" W( ?$ QDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
  o" n/ t! F, d% ^& E1 Y) d: [DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
8 p2 F" q& }" wDDEDisconnect(kanal);# d& ~5 l) l; B- O) d
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。% a4 @/ \0 c% x8 {8 i

7 J+ w$ C9 [' j请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
, J5 c* p0 n+ A+ g, J3 b1 x/ |; t2 C3 ]& D8 H3 a" y; _) n

+ y6 u8 j# X, V5 B4 m) `木有人理我么?4 D8 R0 u  S: Q' E7 x
8 R( r3 p, [) a( t, f+ A8 e
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
9 f; B4 W& o2 h- }3 L; p
( A* `! i: h0 WDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);0 x; {  h% P8 X

/ [" F2 K# Q8 ]; V% j; x( C  L5 R9 B但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
0 ^. z- z# e* E$ \( {# I$ Rdde确实没用过,不过之前用过其它接口,不知道有没有共性。
& o& f1 e4 P# D8 F
/ a5 Q+ K+ S* p. k触发语句是这样写的execute("        'cost'   ...
9 e3 s& V9 {7 X9 h& l$ `
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 2 W8 A* k  z+ K4 {2 ]: h
taoyifei2000 发表于 2012-3-29 21:37
" S2 V* \) m! Ddde确实没用过,不过之前用过其它接口,不知道有没有共性。2 V0 p5 t# D; a

( y( a8 z# F2 k5 D; B8 w触发语句是这样写的execute("        'cost'   ...

; D# O: i$ \& b, E6 v' ^: x) J0 x! x  o- G* ^* O" Y  Y
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。: [" n! k; g% ?2 \! |4 G
, y6 O6 n/ V! y5 N3 _/ h
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 1 J3 t; _& g( F2 R. C" ~* ]% |
若叶繁茂 发表于 2012-3-29 22:03
: l) D3 E5 \# \8 A( y不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
6 w% C, n- {% E$ F2 L0 _

+ v% E+ [# e1 D* y我也没用过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 , b9 W+ x4 H, Z( b0 u+ ~
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

( ]0 q+ d' V  k6 j/ K  j谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。% [, G( A4 |3 a* `

4 o0 e! |: V4 ]我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
" I, B0 c  L2 L) I按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:" R& P% t- Z9 N& [. J5 ?; t" _# a
is
# G- R. l9 H4 Y! h. n/ C        xl: any;
5 ]7 O1 y0 i1 U2 _$ y4 ndo) h1 x2 @3 S" J
        if ActiveX.active then
' Z6 H* @. c& h/ u" S2 p                xl:= activex.application;
% |+ q; S8 K4 L2 g$ Z                xl.call ("Macro_Reset");
- I8 m# |  H7 o7 ]) V' H                activex.active:= false;
$ O1 C3 u0 U) m+ O, [% N' Q        end;% o' Y4 p! P1 W3 e$ W0 O
       
2 |& Z0 e1 Y) v0 M, Lend;
$ f7 U  ?) _7 Z; t% d/ G# M
  q4 U' [9 C4 r- A显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~$ K& G+ P; E" Q
  I+ Z6 X3 u4 A! b  t1 Y
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-5-7 12:04 , Processed in 0.016170 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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