设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4451|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
" w( [2 ^6 C! W" ikanal:= DDEConnect("Excel", "Cost");
# ^; J: q4 `" V0 [3 FDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
4 n, G# w2 b, i6 A. E5 ]5 h( cDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);$ Z% ^7 |- T/ F3 N- o8 ]: O. u# r1 |
DDEDisconnect(kanal);/ Z4 i9 C! J, z5 ^8 E" ]
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。; j/ O! B9 N+ ~. K$ T6 K. h2 N

2 [+ q% ~8 n! x8 D请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
  Z7 R8 P4 G1 s2 O( \% o, M: @; U: R* F
8 ^! u* M- `* r0 C( e
7 m: ?% I6 s+ c( A/ f- K" o: I8 O木有人理我么?
- Y% `1 N" E4 Y, V" U; l1 t. N( ^! D  R
; K, j2 F" \$ E/ B7 K+ Y我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
0 g/ E& g* L0 y: f; S' ]8 k1 g% R/ N% v2 q0 d- o) `+ a
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
- ?# Q$ [3 v0 c
  R7 \% K! l/ L) O. K- @但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 0 b$ \9 D1 N, h
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
. F. J# f8 N( g, z  Z$ n
1 b( a) J! r  s& D6 l1 n触发语句是这样写的execute("        'cost'   ...

: m: O! V1 `1 E; `* U谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 2 H7 u9 K+ ^# Z' @
taoyifei2000 发表于 2012-3-29 21:37
2 V5 E* k9 I4 R8 s5 I% ^- rdde确实没用过,不过之前用过其它接口,不知道有没有共性。8 h6 }3 S8 y- R1 R( g+ B! ?

' u5 J( b1 A1 S: u0 y7 K触发语句是这样写的execute("        'cost'   ...
( G' f9 {& N* J8 T. O, y# J' M1 a
* @' A' Q0 J$ y2 |! s* m( w# L
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。6 ]8 z$ K9 C3 O5 u- ]
: y& b1 B: H; s- K8 f% j6 J4 }# F
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 * l/ U# {, O( M+ ]! [
若叶繁茂 发表于 2012-3-29 22:03
6 f1 w& l; g6 u- d" m1 w不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
2 X. t$ D$ B) |/ O$ H' O

0 A+ ~- b& e/ T8 g1 m3 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
) `. Y4 K: P6 K0 F6 t0 ~0 u/ [我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
" ]6 }4 z0 t% ]4 S+ I6 {5 S. l
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。7 [! Z* J' S( _/ U$ J4 F9 t; l

: @  ~: z- N% M2 R& x我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
8 _- F9 g& I) M: m按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:% u2 T8 P+ ]( i. u" W. |6 C
is$ u& N7 a' B3 b0 w
        xl: any;
, v& j5 b* [$ ~5 \0 Zdo
$ d4 y5 E* u9 m$ ~. K; b        if ActiveX.active then, i5 @* h1 K3 a  V+ g
                xl:= activex.application;" J' u+ |7 Y. W  V+ g
                xl.call ("Macro_Reset");( X- P% ~; a% P0 t
                activex.active:= false;
0 [- w' n, ]8 t% u; n1 K- z( G        end;
0 _4 l# f0 s# i) @6 A. M- {       
* g1 b- J$ i$ u% l; c7 R5 F% fend;
2 C" W% [! r; u& z1 k
) O1 a0 q: V8 H5 N: g9 c显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~' |) \  a. V) q) x+ T

: L. t; |# ~4 L% ?% Y3 P期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-14 15:15 , Processed in 0.016070 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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