设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5107|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
: A% h- ^& P8 T  ^5 ckanal:= DDEConnect("Excel", "Cost");! C% y, L& v- m3 z6 U. X
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
9 ~6 ~7 E+ b1 c" JDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
& g% R% y; Z! c" T0 [- B9 n2 k8 SDDEDisconnect(kanal);% x2 a" H# h6 `: k# j* O2 ^1 k
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
* S" G) S  Q0 q  m- ~
1 h9 w9 j- d9 z* A  k# p) a请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 5 \, K; C. F! Y; L6 s. B) D, S
* _/ c/ c7 h6 n% B& z& T" u) Y
. `6 U- T/ |: S  |8 H6 I. _
木有人理我么?
; B* @( {( S) c9 z7 h  H6 S! Z3 e- E
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
, a5 Y* f, ]/ Y& H( r1 K5 H4 c: }4 j& U$ j, }* a  U
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);. u: s& r' a2 S7 {* y# z+ b
7 \$ R- Q- k% g6 k5 J* c( f
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37   P: b4 l8 {" [
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
, d% [9 t( a, X0 l$ B% t9 S6 n% S$ X5 h) \" z2 a
触发语句是这样写的execute("        'cost'   ...

9 B9 f, X# ^1 x" D# Q谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 7 a1 ]$ P5 I- I- [% I# S
taoyifei2000 发表于 2012-3-29 21:37 * i/ k: p; s6 B, z$ D' O+ j! n
dde确实没用过,不过之前用过其它接口,不知道有没有共性。6 V! N8 f2 l. H) P& Y2 X

0 V* T: r& @2 M1 P4 J触发语句是这样写的execute("        'cost'   ...
' A7 h' {% W6 C/ e2 U6 @. ^

: q' I/ B1 D8 B3 G, w不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。0 ^: l2 T+ w- `8 j" ?1 x

$ j  N' \! R$ M* s# B; ^诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 2 c- R# c" Q; O9 Q* |
若叶繁茂 发表于 2012-3-29 22:03 + l) C3 X9 u5 V: I. Y$ u
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

) |4 X7 R# T! E/ I5 S4 t# d7 L. k% G. B& n3 {- p0 ~
我也没用过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 V" J+ ~$ c$ }; x2 @3 i( k9 O
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

0 @, h& w* }3 h+ Y  o9 C% Z# L4 _谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。$ O7 g' B/ c- B* w# ~- f
" |$ l% ]/ ~) }9 j; p
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
' }5 H9 ?# Q0 G# d$ Y5 ?按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:' S, @' j/ B  F# w" K) T
is
9 w* L3 w2 Z0 \' [  C. n        xl: any;
( L1 r7 h8 Y; {( edo
$ m* y0 x/ Y% m/ h  y5 }. _% m2 C        if ActiveX.active then  o' r( u6 M4 U- b! F5 v- p
                xl:= activex.application;
3 ~  {  @% |' ]' Q7 u# i2 W$ A% Y                xl.call ("Macro_Reset");" b* f6 f, d) n7 u
                activex.active:= false;
- \" \: m; v9 f        end;% C( k% ?4 o  J& z) V4 Y2 W
       
2 I( r: e- t7 ~2 qend;) f$ Y5 m* H! {7 ^8 F' T

; Z8 U/ x8 {. J5 @9 l! x显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
$ q% @$ Z7 v' X& |4 E( s
! v' A& Q  r% i7 f9 ?9 ^) e期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

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

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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