设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4035|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:2 {0 Y  K; x7 [" X  t( ~: U
kanal:= DDEConnect("Excel", "Cost");
1 r) |0 G7 c% a+ y4 P- iDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);, z3 D9 q* W2 j3 V3 U; b
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
- L, H& C9 h% i  [5 Y9 d  m% mDDEDisconnect(kanal);
) t+ D- ?. C+ b, _  [3 ~: n系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
8 M  E. n5 w* m5 F1 l: c$ ]/ Z
; m: q' Y9 P7 M6 }请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
: l$ {' ]9 s1 H: H0 M' Y' y
: [! ~3 ^- B/ |4 r( d4 M- d1 h: D- m1 k
木有人理我么?2 O, h( S" r/ H6 d9 ^# M
  d8 M+ K2 d9 P$ d* T% r4 Z3 v
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:! ~9 j7 N+ s5 Y- A# U/ W/ L

) c  f* K. k9 q0 u* I& y+ ?$ [DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
% ~; \& G* s. s/ h& o5 e' @: L% G) H
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 - V) {3 `  {( A% {" w. l
dde确实没用过,不过之前用过其它接口,不知道有没有共性。" y! R3 O: g9 ^! D0 H0 f
5 U3 T. d' X0 o* v, E) w
触发语句是这样写的execute("        'cost'   ...
$ @8 Z2 {/ u" \5 Z
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
2 w# y* U# e% K. Z; }
taoyifei2000 发表于 2012-3-29 21:37 / B/ d  m; ~! D
dde确实没用过,不过之前用过其它接口,不知道有没有共性。8 ?9 c7 c& Y- v

9 `8 [) o% M" l0 A. t/ D触发语句是这样写的execute("        'cost'   ...
0 [, b( g2 ?1 U; i5 u4 k
7 U$ @  B1 M0 f* d% l7 X
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。5 j4 `" _, w7 u3 z

6 L% W% F: G# q( p! q诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 + r6 S8 K0 H0 c* R& `
若叶繁茂 发表于 2012-3-29 22:03
3 w3 G  M( H/ g! ?( |/ d+ {, P不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
# u" w: `' D1 V  g0 Q
1 [6 J4 t4 `; a# S4 ~6 [' 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   c. z, U/ \  u
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
$ C6 a& l6 h% T
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。4 Q. {/ l8 _( s; G0 D

$ A; U3 n4 A# y; r% S# E7 D我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
# b/ W2 M6 U; C' b* i按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:. X3 A( K& H7 |" l
is
2 G" B% F! l0 I2 L3 l4 q4 g        xl: any;, I9 L* a! G, k2 b! \8 [; s) [' M" b
do
& t. X1 \) G$ Z( s" t5 x) P6 D        if ActiveX.active then, I. e/ e# j' y7 T7 ~3 {& t
                xl:= activex.application;
+ H0 a+ z* D# K2 ~                xl.call ("Macro_Reset");
* Q; b2 F9 ^9 `" Q. j/ c6 m* A, G                activex.active:= false;; v+ W  e8 A! k. t7 R
        end;5 N2 s* w( f4 X$ b! k% v: t3 e1 H
       
& g; ?/ ]" m) d2 W7 _end;! n5 o$ m1 ^+ M" ?' I$ R3 G/ i

# m6 x2 z: Y& ]4 l0 E4 y! r显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~6 [) ^1 G& F% d  w

$ c' Y* G  q1 u) E: d2 _0 r+ @期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-12 14:27 , Processed in 0.022187 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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