设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5381|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:' y3 k5 D2 y/ Q8 O7 R1 r+ C
kanal:= DDEConnect("Excel", "Cost");2 ^; {" r+ P- i6 c
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);$ T4 P! Q$ K; @3 d+ K
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);+ A9 A  Z5 U/ g- L
DDEDisconnect(kanal);; p7 \; J0 ]3 y( W: L
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
1 D7 j. z: s! v  [7 Z6 A
- u2 w! b$ t) q, ?- h请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
) c* B! f) H; p4 C/ Y
% U9 z9 @( p- e7 l
/ \; L5 j4 n( r; @% D2 i: o4 I木有人理我么?; Z$ s8 o' P5 t% o

* _! d. r: b' q, \! ^我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
3 ~# M) x0 o+ n$ S1 J: V8 h, T7 o) F3 E6 r
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
3 ^; w) X9 k( E$ @' D& n3 s! z, J2 Z3 J9 Q6 v4 J# v, x. v/ S5 i
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
* w5 ?  u# L" ~dde确实没用过,不过之前用过其它接口,不知道有没有共性。5 n$ Q$ d' M  V

8 |4 Z1 ]8 `; w/ O( t+ P! A( p触发语句是这样写的execute("        'cost'   ...
, R7 a1 u* W5 i
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
. c+ e% k; Y1 Q8 J( d% ]( m; C/ d
taoyifei2000 发表于 2012-3-29 21:37 3 R' v1 o, R. i! ^; S$ M+ Y$ D
dde确实没用过,不过之前用过其它接口,不知道有没有共性。$ h0 p, ~( J, v6 m1 Y
9 c& X5 G. k, Y$ e& Y4 w& U0 ^* ]1 {
触发语句是这样写的execute("        'cost'   ...

' ^9 u- C" P+ {* z2 q, ?4 Z3 Q+ I9 u$ z& _+ V$ A0 {
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
6 i" i+ B. \! q# I# M5 n' z( q" O) i1 k# S+ k% E
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 8 `9 w3 ~6 J( i' i# g: z
若叶繁茂 发表于 2012-3-29 22:03
& A# E& k* [- ?7 \7 P不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
  B6 q& {# `& G" `5 E5 ?
  v( L: V  k* d1 N2 b! Q( W
我也没用过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
) m/ W8 U8 @- ^  x. |/ _1 A我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

, E- i/ j) z; W  q# i- C3 T谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
6 G# \, D+ {& U8 |: a, R' v. j2 i$ ~2 F' c0 c3 U6 \8 C
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。* {# \0 \9 i2 j8 w# @
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:6 W* o  e' i0 G& r/ ^& {: c
is* N- S& W+ O4 Q$ ]+ F
        xl: any;2 u( z% m+ q# ^  R9 C$ D0 G
do
8 H, d! u$ J$ G0 e        if ActiveX.active then7 b. \1 F" x) W) ^3 z
                xl:= activex.application;
$ k* }# z6 O9 I! K                xl.call ("Macro_Reset");
1 j9 I, Z$ g8 _' H% ?2 n* W                activex.active:= false;' y- b" Q8 k; v
        end;' ?, ~' `% A; a
        ! O) r" K4 u8 ?! |
end;/ t# l' J- m( G3 ^6 g

3 h; m3 a! X: E/ q5 W; ^7 ]显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
6 r) B% L; J. l& S5 a8 h8 F- g( w2 V0 `( p; U, m- C
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-4-28 12:25 , Processed in 0.015449 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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