设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5106|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
: v" w: s0 @4 tkanal:= DDEConnect("Excel", "Cost");
4 D+ a2 O  ?) i8 P8 @4 o; x: SDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
& I( ~& B. Y0 \4 ?  c* fDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
/ M& r. \+ w+ F% s' N6 y) RDDEDisconnect(kanal);# S" Y+ W: P4 n( |2 Y7 N; P, V: ~
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。- x  j- W4 ^1 A5 M
0 _+ n- o. r: x5 T
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 7 ^3 A4 D& }" i$ V. b

- u! g* `3 r( m8 t; Y( B
( T$ a" l: J, i: U& u6 K木有人理我么?
# z# T. C! l6 B& P0 }) h
. G5 C: d3 `6 a* M  A" I, s" w我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:- ]7 u& y. q4 z& l! a2 T- z) q% k

) ^; m7 s) L5 z8 f6 tDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);" d& X, Z" p% E
: W* E7 j3 p* X3 U# h
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 # _% T6 m3 ]; ?. C
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
" L. d; i: J2 z2 ?
* N; L* O" {5 Z触发语句是这样写的execute("        'cost'   ...

) ~1 [4 l0 J( Y/ C9 A& [" Z谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
' u3 y1 E2 y2 ^+ A, E1 T' I
taoyifei2000 发表于 2012-3-29 21:37 6 |$ e* o2 Z' M3 r% o4 ^
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
/ d, e2 U; D# r. K) k  V. {* P0 V! h% p0 L( ]# ?4 v& v8 b
触发语句是这样写的execute("        'cost'   ...

3 J/ p, d# R, h" s9 x1 G6 L9 b7 V9 B
, Z5 c5 q* J# [不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
# i( H* D6 H( x& P7 F( n
. I, U5 C+ x) M; `; X" \8 e8 g诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 0 a5 u0 Q4 @9 r! A, O+ `
若叶繁茂 发表于 2012-3-29 22:03 7 o7 ?; E" [6 b5 r
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

  B4 v6 m6 G" f! D9 h; P; z! z1 t& d/ P  B8 Q, U5 ^* p0 C0 @
我也没用过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 ! U$ p  x1 r' B$ \
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
  w/ }0 @5 n0 u& W, y7 P9 j" m
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。- L3 F" B; V  D

$ a6 q3 w5 d; e+ Y我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。) I& a- E" p, y+ K4 [
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:6 p4 g! e" Z- t
is
7 U' j2 f5 l6 H* y. q        xl: any;
2 k& F2 j+ b" ^7 F/ Sdo% u+ k( [3 J7 Q# @
        if ActiveX.active then
# V) G& P% S3 Y, N$ U7 B                xl:= activex.application;
) E# z/ o' N: I) W9 K8 R' I                xl.call ("Macro_Reset");
! e( V( D# e) \+ s, W8 v" ?                activex.active:= false;
! `( W: {. p& _: U* Y3 v; {/ M        end;: J' w# d0 ?- D: i, V
        0 N+ X' r( |9 L( s8 ^3 W) Q0 a
end;' R% x9 f5 i! H

. f+ H0 g  `: X显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~* o( l) {/ p4 c3 y
! w2 }% C- z9 v5 R1 k& v7 u
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-6 05:31 , Processed in 0.016346 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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