设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4398|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
: s7 m$ M/ \8 z* ?' u& ~kanal:= DDEConnect("Excel", "Cost");
* j+ G7 i$ U: q* Z6 V; \  v( nDDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);$ h( y6 b- m/ D7 m
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
* {8 F, ]! n$ R9 t- QDDEDisconnect(kanal);" g. J2 K4 l- I$ V. B6 e; h
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
. x  h" s: t# |
% W" P* {3 u/ h# H请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 5 r- [8 F5 S; A* V% D5 m/ K

% X/ o: O+ d' R8 }. C+ g' Q0 u
9 R" h7 |, l5 F0 |( [木有人理我么?0 F6 z5 k4 x0 I1 C& j0 s3 Z, _
3 t  @5 B& e  f4 y% y
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:# G! d6 N% p6 i: ?3 C

! Z3 [% _' W( Q2 fDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);* D# I3 n1 _+ R; S
: M# [- p6 S! b; w5 ]9 J7 t2 a
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
3 n5 M! Y/ j6 Ydde确实没用过,不过之前用过其它接口,不知道有没有共性。  u1 J( Y) V' f) a
7 j- t+ `4 ?2 c  t1 E* B
触发语句是这样写的execute("        'cost'   ...
0 }" Y( p1 b  ^; i: N
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
; e1 H. v1 ~2 W
taoyifei2000 发表于 2012-3-29 21:37 , k9 h8 W( ]1 N& k
dde确实没用过,不过之前用过其它接口,不知道有没有共性。# ~* a$ B1 I$ o1 ~

5 h+ [) k( i" G- @5 H触发语句是这样写的execute("        'cost'   ...

# L2 F' B1 s# W4 W6 _3 w$ M4 ?% m& k2 Y4 }6 V; O
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
; T9 w9 o5 H* v- i0 L! _
% M* x$ v9 @4 U6 e+ M2 z诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
" [; c$ w3 ]/ P, u- S8 M
若叶繁茂 发表于 2012-3-29 22:03 ( C" |0 w' B9 w0 ^- l
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

) r. m7 a" D# o% }. r
6 O5 ~; k( p! r9 s2 H我也没用过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 . W5 x/ K1 @2 j& Q+ n- i
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
; _% O  n# a: `6 ?5 ?- x
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
8 F0 N% d0 V( j8 i# [* v* \- T- ~  n8 S: U
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。
" j- x3 U8 G! C' r% s按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
/ e7 w% N6 R0 D) y  i8 E' vis: d* b  |& G% k9 d0 D
        xl: any;
, Z; a" Q  J$ x0 B# S! \5 fdo
) R; `; L$ h& H, _) y$ D        if ActiveX.active then
6 R; w. M% `( K* d$ R. v2 w                xl:= activex.application;0 {$ [$ W! k7 m; o2 J, R3 [9 \8 u
                xl.call ("Macro_Reset");" v( |  H/ f4 x  b2 r% _
                activex.active:= false;
3 O# F1 J6 K) C        end;3 X# k* z/ W) }+ m* V& o
        - G8 v' C7 m8 w2 P  L! @& R
end;  s- \$ t' e* X1 N+ c* a
% z3 Q: k2 \% |4 h9 |% p8 o* v6 }$ f
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
0 C( f6 _3 I- H
0 q, ?* S3 v# l' S( K期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-10 19:08 , Processed in 0.014759 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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