设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5341|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
; x1 B$ `0 h" Mkanal:= DDEConnect("Excel", "Cost");  N1 @6 f2 A, o- P( W
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);1 v$ \$ o; [3 M  M
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);# w8 _. n% I$ N9 V2 B! {/ j
DDEDisconnect(kanal);" J( P+ g7 S8 x$ u* M3 L8 F
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。9 o$ `+ R  v. _/ k) m$ A. _" B
4 N& A8 H" P$ E3 u( l
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 + I; q* S1 O4 r; `5 _

% D; Z4 I+ A. Q! X& y- N* Q) f! g# N4 ?( q5 T8 K) X
木有人理我么?
4 A' w( V6 v- x- D* Y
7 Q( j$ |+ m$ Y/ i0 t( O我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
* k) i; _! ~' L1 C
/ _1 w' ^0 N; z1 @( V* H1 UDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);1 w; R3 ?' o4 R
) w5 j3 T# K# \& B, T1 C, P1 c
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
! j2 y6 w8 }% adde确实没用过,不过之前用过其它接口,不知道有没有共性。0 V8 [6 L, Q6 A0 ~1 K' u
( q) `. I' C7 I" v. ?# V
触发语句是这样写的execute("        'cost'   ...
# |: c" J; L. R3 r- V( I. D6 N7 E
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 0 Y  ~. U/ b3 H; E0 z* y2 o1 X. {
taoyifei2000 发表于 2012-3-29 21:37
/ @7 a% Y$ T1 ddde确实没用过,不过之前用过其它接口,不知道有没有共性。# [9 c( K( P- R2 r* p4 L& n
+ c$ v9 s- c1 N* Y
触发语句是这样写的execute("        'cost'   ...

( i' l, b: f/ Z/ D; n7 R9 k+ L  u1 Z
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。5 I+ n! r1 u1 Z- s( ]

1 L5 Y% R. U* I: f( G+ ~诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 $ s" y, P$ c% k  I" V* H
若叶繁茂 发表于 2012-3-29 22:03 % G0 X, G7 j. U* a% ]0 h
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

$ H7 \) z: u& s$ t, V
7 Q- g- w  K1 J5 F4 \7 s我也没用过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 5 l. {# b; k9 Q- W' U$ s
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

, q8 [0 J; d& v0 x% \谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
0 \2 S* X3 k/ b# \4 w
. ^3 }% w9 R5 `  n* j+ G我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
. G$ y# k) C# h; L: ~+ z# U按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:8 U; q2 i, G( U! v' Q- q3 ?& H
is
9 r5 `- n" m3 t! P2 H4 d8 D6 o        xl: any;% b4 B. F$ |( v5 I! a
do0 o: O3 b5 P+ Q) J  V$ k: l3 C
        if ActiveX.active then
) Q7 \# ^  p  w: f                xl:= activex.application;/ U4 T2 M- b- N9 V/ s
                xl.call ("Macro_Reset");! L" J- f( ^$ a" r6 A% Z( m3 g
                activex.active:= false;
. x: R, E- d1 f1 H        end;' s: R* C& R' Y0 B8 A% E% H$ O( q
       
+ d: s, A& R  `; Cend;7 }, B! D+ V$ b: F

1 V, o  |; k/ l4 C2 ?6 s显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~; z/ Z; ?- K" }0 u" k1 L' n) w3 ~
; a  [0 ~0 k4 o0 r* P
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-4-17 23:29 , Processed in 0.015046 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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