设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5496|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:$ `* o- B& l1 m
kanal:= DDEConnect("Excel", "Cost");
' ~1 q4 _* l$ E# H% gDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
5 T/ L8 g* h5 u# u' oDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
3 I$ T2 H. p3 I; \  G7 F/ w+ lDDEDisconnect(kanal);! i/ H# W% K6 ~8 p3 V6 L& D
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
5 p6 a) _- G' z& f/ R$ k; d9 N! G% E) Z- Y8 p( j( O
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 3 D" _* d" K6 s

4 w  C( Q/ j% ^: X) [& c( G$ z% M* G: O# w+ @, d
木有人理我么?6 X; c" q: c5 ?/ D

+ E5 `9 s8 r( q  j- R" I/ n我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
7 q9 ~5 Y8 \# H3 t4 a# z  |
" R' u, R. J) jDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
: w/ a6 C$ L7 r# A# E* R6 E2 q% y! a
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
8 u. |& x$ W, m+ Y) Ldde确实没用过,不过之前用过其它接口,不知道有没有共性。3 E3 ?% i5 A) n/ z8 Q
: l% j# p2 u9 A* F+ K
触发语句是这样写的execute("        'cost'   ...

8 Z4 _: w2 E( {7 B谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 : u2 ]% S) w! Y+ y- t1 ~' P+ L
taoyifei2000 发表于 2012-3-29 21:37
4 m5 y) N- y% H+ E" x* xdde确实没用过,不过之前用过其它接口,不知道有没有共性。
( y8 P1 M0 A" u4 k. E' {
7 F' r9 \; {+ c/ y: d触发语句是这样写的execute("        'cost'   ...
# r" m+ J  V/ O5 Y& z
& O& j7 C: r$ N5 j; G" d
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。9 r2 s4 D/ i* k
- Q1 D3 H- O4 r3 x6 {' p7 k
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
! E1 @2 Z! Z* L, f$ y
若叶繁茂 发表于 2012-3-29 22:03 ! g7 Z" k/ I. P2 b
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

. {! ^0 r5 q* L7 t: v) g! c  a9 I1 e1 p  s* g8 r/ K, C: R) [
我也没用过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
8 l. E( m& P) U7 ]. V+ L我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
! w' m% y4 R6 C2 t9 M: ]
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
/ |" m& X/ D; m- S
, Y; K# e' b& q/ |! g8 l我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
1 s3 l; J* e( D1 e按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
" \7 t+ ~& [$ d( s; Iis
- ]7 I4 \7 }" N  i3 ?* g  z" f. e        xl: any;% ]1 v4 \2 S7 N1 I* L& E- ?) M/ [: b
do6 {( X  k6 c  G
        if ActiveX.active then
) \! X' s3 H, C% H; `$ f* E3 `) P                xl:= activex.application;, L) k( o" x. R1 v: A' N
                xl.call ("Macro_Reset");% ]6 q! b5 F6 ~* r! j
                activex.active:= false;
7 @! u( [* J$ E' J        end;
0 ]1 y3 L+ R- p  _       
! P$ q* z& p' G3 q6 h! p) Cend;
0 F, Y* K7 a$ w7 ^7 H% V. V; y7 m& P% v6 l
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
" F) z0 C+ Z$ A9 ]# `" N$ N4 }$ s: }! Z! T
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-15 00:37 , Processed in 0.013744 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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