设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4711|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:7 q4 m& \, D( a) C
kanal:= DDEConnect("Excel", "Cost");
+ r* q) c' ~) V3 p- A7 UDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
: p" J% i4 {0 S6 h1 E  zDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);+ b* ^- l0 l7 Z" q% N" j6 P2 h3 m
DDEDisconnect(kanal);
8 T8 a* @& r% ~系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。4 E' ]0 I2 M. `7 ?! x

' S* Q' l2 Q3 ]请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
& P4 w2 J0 U: X1 e/ C2 v% m
/ j) b( u# W) \0 C7 f
2 h+ e! B8 L4 i/ |& ?* N. ?/ Y6 h木有人理我么?) Y, A; v$ A0 Y7 u
) r- T* u' p+ V1 w1 y
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
9 X, m. T8 Q. z  e* B8 \, `% R1 Q' b/ Y
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
0 c7 e+ `7 w$ a, H& I* f9 `* B0 F
& C  r: d8 ?# N5 p但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 ; i1 o( n4 N1 D0 `
dde确实没用过,不过之前用过其它接口,不知道有没有共性。' G. ~5 j1 I( v8 _5 E7 \& t& G
! Y7 r' Y/ m6 S! l
触发语句是这样写的execute("        'cost'   ...
0 L. g& n1 v, c' j) Q
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 / C! M# A$ s  y+ T. L7 m7 P
taoyifei2000 发表于 2012-3-29 21:37
( v3 o7 q6 x' Udde确实没用过,不过之前用过其它接口,不知道有没有共性。
: W/ ]* U7 P+ @) j( \
" r; I$ d4 F: X4 g( `5 n触发语句是这样写的execute("        'cost'   ...

" S" p, F2 A0 D# K! G
. t1 K7 R# T$ o$ ~1 }' w4 S不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
* a! }7 D7 C  a4 x2 \1 j# ^: m$ d1 S3 n6 G0 B
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 + D5 [! @( k1 x" y5 v$ m
若叶繁茂 发表于 2012-3-29 22:03
" v& l* R, c+ y" K9 m; c7 i不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

# X+ K. E7 G) d+ ^/ ^2 m
8 q5 J: q! f' U  ^我也没用过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
  a: X  [) C; o$ v1 m我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

, s, h5 b$ f" p谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
' j9 Y6 Y$ ]6 i% \, Y" i5 K' X
& B' f3 w2 a) }& x1 Z, n% Z% Y/ v! k我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。/ y( i6 J( N# B( {; v
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
, Q/ A( Y: y8 I: }2 r% U$ d8 a* V  {is5 h5 ?" K: T1 x( K" Z
        xl: any;( R; ~4 `; Z: Y1 j3 ^# t! W
do
( T: v! u; i" C( B9 y+ U, S        if ActiveX.active then! y& N( p/ d; I! G' m% h4 K: W
                xl:= activex.application;
" _3 L2 s, q6 N: L. f3 l- U3 p" a                xl.call ("Macro_Reset");
/ n3 z2 X( A) i2 U                activex.active:= false;
, v* z) Y: F4 q# K8 @5 L        end;4 m/ X+ C& F: W$ A& G& I% L/ U
       
! n  D0 d3 `' e0 C8 D! H0 Cend;
) q4 h; H( e5 ]/ V1 Z4 l# F6 \: V( q4 S5 t' ~" `, O0 e
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
4 C2 t8 V" {; b8 Q2 Q
2 A- z, `/ V/ `* Z% \5 h/ y! G期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-11-1 11:40 , Processed in 0.270367 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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