设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4034|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
2 C8 [  ]6 \$ y, ~. ekanal:= DDEConnect("Excel", "Cost");. B" a7 e( `, ?) X/ a+ _
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);5 I* n0 Y  _3 e: F+ S2 M( z. T
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
7 J8 O, c$ x2 x+ QDDEDisconnect(kanal);
5 I9 R/ |9 @: C& I+ A8 {, d0 ]系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
% [! v; S& w5 k0 G# [+ |- {' \; U* t$ O; \. D. p
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 ) ?& i7 w2 _. H( |% d1 E! T0 E% c# L
# O3 \, k( J$ i& x5 n/ k! g2 ]
& K" i( G/ }. T- D2 u0 x
木有人理我么?: a8 P  h+ \4 b; g, Q4 z5 m# d/ ~
- N# M4 J! y7 Q4 E  E! n
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
: ^+ H2 l! e: @) L! z% H; _$ o% J' T$ s$ I( A2 }
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
4 @' W4 X$ ]  `& d, a6 Y2 |1 ?3 d* e& F5 k8 {! ?7 W
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
7 A% l6 S6 c( J0 G8 w7 b4 ~dde确实没用过,不过之前用过其它接口,不知道有没有共性。
5 s/ |4 b, `% E! l0 {8 f7 _" @" F  |4 @( u  u2 q, ~% M! t( F
触发语句是这样写的execute("        'cost'   ...

! J, j0 C+ d! @3 X- B( ~: h$ Q; f; s谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
7 q* o* z% k, W/ Y4 N$ ]2 u. \
taoyifei2000 发表于 2012-3-29 21:37 1 _, g3 u& h5 d% }5 G) ?# T8 R. x
dde确实没用过,不过之前用过其它接口,不知道有没有共性。5 d/ H1 G7 E% I2 K! c2 M- q; H

9 h0 T+ U/ u& f$ q! ]8 p% `触发语句是这样写的execute("        'cost'   ...

% \+ `+ D- S: t) d1 |! M+ q0 _" t1 T' @- W5 S+ M
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。1 Y( M& R. t* p! J! T6 q' [
; P- O# G: i8 x/ e0 F  J
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 4 I; p9 B9 @6 M" d  S
若叶繁茂 发表于 2012-3-29 22:03 8 @+ r, h9 u3 Q( I; l
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

# f1 F7 Q9 c$ [( b$ l
& `: }' b. _' R+ Q我也没用过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 $ F* G+ [% ]4 Z6 T: J4 Q5 Q
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

& }/ W! S# b- f3 z谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
& i2 |4 g' g% I( C. g
$ F: R2 U. H: z. S& y1 X我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
& B! c3 P& l% u按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
+ ]( y7 l5 s& R/ c0 {is3 ?% F( ?( D6 y5 a6 Q3 K" Z
        xl: any;
- M6 K1 j/ }! zdo3 ?6 k/ @; F8 n$ w# I9 T) W4 E
        if ActiveX.active then% l1 v. Q: i& G8 \
                xl:= activex.application;* S2 e8 L% V- x3 Q) |* }* n
                xl.call ("Macro_Reset");
9 Z/ J$ Y  ~5 F7 M3 [                activex.active:= false;7 I" v# w6 `: k9 s* i8 P9 A
        end;
8 B: O3 v- V1 p) B! c0 F7 t! o3 i       
2 A; p0 r' W( }5 j0 {. |' ]end;
1 P1 ?  R7 a; F5 F' T
7 v: ]. G( {3 ^- w显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
0 J4 D! Q4 j) S' i0 F) y+ \5 ^: C: Z! @7 a
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-11 20:00 , Processed in 0.019576 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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