设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5163|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
0 H" s% h$ p# c2 m% c2 B3 ^/ o  ^kanal:= DDEConnect("Excel", "Cost");5 F3 ]+ n: w1 E  T& j2 G4 a
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
. l( `* L; |4 P# \: H$ |( @& C* {0 Q0 ~DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
; E# W) ^# A0 B! e+ uDDEDisconnect(kanal);
/ J7 z& s2 Y- @系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。" |  p4 W5 x# Q- m

% O  W% U# t) F  Y5 @请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 ) |3 H/ K1 W) g- I3 E% J. Q& `% d0 f

# N6 _5 |6 t5 t" `! _: z2 Z' o( b9 g1 v, z, [
木有人理我么?
9 ~. ?1 i$ h; C, v$ b9 [4 V8 Y" ^4 m. F( [. i
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:' d) E( ]- L$ n2 S) {' A) q6 ]
0 N% m8 _7 k4 w" I, O
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);1 O1 p2 \! S9 G9 ]# [

  ^3 B5 a, K  a/ R但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
$ y6 _6 B+ S+ U' _3 ]! fdde确实没用过,不过之前用过其它接口,不知道有没有共性。
% Q& U# c5 h2 z7 D; q1 [
& v. U2 n- `: D1 o9 l6 c2 R; t- x- }触发语句是这样写的execute("        'cost'   ...
3 l/ `1 M& t  a
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 ) Q" c& v4 }+ e8 ?9 G+ U, W# k
taoyifei2000 发表于 2012-3-29 21:37 ! n, N" M( _: ?; U3 G% w
dde确实没用过,不过之前用过其它接口,不知道有没有共性。, M, l# h5 ~4 O9 W9 z( Z  i

7 i0 F; C2 ?: a% V/ ^, E触发语句是这样写的execute("        'cost'   ...
7 u% @. v) X% G% h+ v

5 e: D1 l1 n' O% e不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。; |; K% @* P" J  W

) y# J7 q2 C& I8 L) H6 t. ?诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
' N: M! c7 I% S3 _
若叶繁茂 发表于 2012-3-29 22:03 , O. i* M* b. O8 o  ^+ E" V
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
: f) H6 t  N+ j, t5 v2 [- m
5 J- E' b; T  ?" \" D( 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
0 ?0 I. p. ~. X8 Y; C3 H我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

: c- G) l) B1 D1 [: v9 o- @" `谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。$ s, W7 S6 h# Q8 g* J# L. _

$ m  {' t; [2 w/ n" y我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。! U' g- ]) y0 I* }8 m) K2 }
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
6 F# E% J' j; J& A" Tis
5 k4 R; c8 ]1 \: V        xl: any;
+ Y4 ]% }/ W( Tdo* w+ L: e) R- t8 w1 K
        if ActiveX.active then% P# D% S3 I1 e
                xl:= activex.application;, n; x, [* |- A8 W" ]8 l
                xl.call ("Macro_Reset");: Q- ~5 `+ e" [; r% |# D, N  |6 `
                activex.active:= false;
' @5 K) M, B% ]% |3 o( l- P        end;
7 C4 q; c9 P% L* P1 K. G       
) E- V) H' {/ Q, a0 c) d* H2 Q2 Vend;
% V. l3 X& k' [2 g# u: \; s
2 V* ^- @/ T. r5 k" t; K2 x5 F显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~% e) T$ N, \( J# o4 [
+ \; ?  }  [. J: r- m
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-21 15:31 , Processed in 0.016862 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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