设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5225|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:8 L- p4 g7 n7 B- G, n- Y
kanal:= DDEConnect("Excel", "Cost");
9 A; g4 C$ m  r8 v' ^3 z9 lDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);! o9 l" A. }) I' Q+ k0 k+ j
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
4 z& C3 I% x1 x6 ^1 IDDEDisconnect(kanal);
3 {$ g* x: A' D7 G2 T# M系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。0 V0 o+ P) v! ^/ {) z* a" y

$ ?& `: r+ {0 s' }# i6 W, D+ x' B请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
' \  q5 A; I3 M' L1 E! E& X% J7 x4 ^) N: M8 O9 S- z! W0 u' G

4 n. x% {8 f/ U5 Q/ w6 D木有人理我么?" i3 Z. f6 A, K; U# x6 f2 R
9 L& L7 a8 a; q6 F  x8 d1 l5 b
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:/ X: j8 y/ C: x- y6 a+ J$ H

* i( c+ ]1 v; f! E* q! g3 o$ t2 ~$ ADDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);9 F! |: @' j9 |
9 W9 N+ p# `% B. g4 \' X
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 + B! E% i5 _0 q% Q1 ^3 u! D
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
8 Z( c- v; p6 Y
5 ?" Q# A3 m" K: k+ @) x, j+ b7 i, i触发语句是这样写的execute("        'cost'   ...

8 a9 \5 ?. J' a- W谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
, l& [% {- w5 V$ D/ E
taoyifei2000 发表于 2012-3-29 21:37
: l+ a' i9 \+ C$ |: Idde确实没用过,不过之前用过其它接口,不知道有没有共性。
5 \5 V7 z4 ?9 J9 v+ w' C- B1 `2 [7 o6 W+ O+ a6 N0 I. {2 `" F$ O5 X
触发语句是这样写的execute("        'cost'   ...
% I* k( S  x" k

6 j# E4 y9 M1 L) [$ v$ Z9 o* x不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。. }% I& I$ N3 F$ n3 _

; S8 X; ~* q" J诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
! H8 Q) g" }+ y
若叶繁茂 发表于 2012-3-29 22:03 3 P: ]3 p0 {( r! c4 c& ~
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
; u$ W% }& b. Y8 B7 L: D/ {7 ]& c, p

4 Q: ^5 Q1 K; H& `# d' x我也没用过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
% ]+ _4 \2 G4 U# O2 i我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
. g% ]% g& B* m
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。3 Y# _  F( P) {, r

" `4 ]% X1 Q$ i我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
/ |8 q0 n5 Y$ k6 j+ E按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
) K8 I6 x( z5 q; U6 |: \* Ais* V  ~8 V0 B3 g) K
        xl: any;; v" F' e! J: k
do4 k" q5 n  w( z' A
        if ActiveX.active then0 B. A! C1 z/ }& W$ V: v. Y
                xl:= activex.application;
3 I3 H2 X; Q6 y                xl.call ("Macro_Reset");+ g- f% J8 f8 A1 ^. K. L
                activex.active:= false;; A- q- z4 D' d1 h
        end;) e  \1 U/ j& R7 K
        4 e, H% u3 i4 f& E: o' A
end;
: e  y$ k7 f/ A. w2 Q. v9 n7 u8 {5 |/ O, h( E$ p- C1 i" d1 f1 e
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~3 l# l! p% O( _7 r
2 u8 f: g, s) V. u0 T
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-13 20:18 , Processed in 0.016515 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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