设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5164|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:
, p8 Z' A5 A& J5 J1 jkanal:= DDEConnect("Excel", "Cost");/ N. V- X. I' E4 p; K4 h
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);
* [1 f3 p6 l& l4 lDDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);0 f, Q; K# j4 l' [% Q& U
DDEDisconnect(kanal);9 Z! j0 A4 B3 \
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。4 e5 Z0 s/ j! d' ]
& G1 Z/ S0 C, i! w0 Z
请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
' g/ o2 {2 Y/ b& N+ X. h/ [# L3 e  E8 F$ @1 p! _% {, h; G1 y

& Z" A) T# s, S6 A- Q# f# k木有人理我么?4 c0 b6 v" I6 R1 P
4 ^( i, S' `5 O- q1 G
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:" M, I+ O9 L; I- ]. R5 J
) u1 ]6 g' J2 |# R2 K. x3 t
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);& m  M! m2 a5 B: [, z

; {: R4 V9 k$ f' D% b但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
- p0 d6 q' T! @4 q0 ?dde确实没用过,不过之前用过其它接口,不知道有没有共性。; {% A7 n  {6 k

# K9 A' a; H' j" U% k触发语句是这样写的execute("        'cost'   ...
5 s# m8 o; s3 i, O5 Y1 W: F% A
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 , u. a1 `  |% R4 D( J" N& e
taoyifei2000 发表于 2012-3-29 21:37
; s# I. @2 v/ |$ j3 |7 B0 p, D4 Edde确实没用过,不过之前用过其它接口,不知道有没有共性。8 d' `! N( @* x  j6 }, h9 n( z

" M8 P- m% Z5 J; j2 K触发语句是这样写的execute("        'cost'   ...

0 `' l+ I* e3 i: ]' A5 N8 F/ B2 ]+ ]% f3 b. }
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。% d+ n! ^1 |6 M* {1 b
. [, w7 p% m( a
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
0 m2 U# u: C+ l$ d! h$ g
若叶繁茂 发表于 2012-3-29 22:03
2 o* Z; [+ |: N4 v5 N, _& _2 R/ M不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
1 w/ q, e: T1 V( J/ ^
& e4 v, p& s9 U$ O3 ]" \0 j/ O: q8 ~* c
我也没用过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 9 J& n- d8 S' r% ^2 j
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

9 p. h5 a) S8 f, t  m; Z谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
. N5 z2 @; E6 E
- m7 U2 `; W+ p3 `. K0 m" D我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。* L& [6 c% Y9 `( E' z
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
% F; ~4 W# z( v( y+ ]! Dis+ P- c% w- h$ w# k& D3 q. ~
        xl: any;
& u  [7 J$ P4 I1 C  R* Sdo
" }6 l* S) O, e6 ?- f0 ~- x        if ActiveX.active then
+ u$ i2 b/ h  J0 x8 `/ h" f$ u                xl:= activex.application;
2 D) k( i2 D/ }' g                xl.call ("Macro_Reset");# b0 N9 r1 \8 N- `9 R
                activex.active:= false;
2 f( D' c* ?! z) {( C6 K8 I4 Z        end;
- I4 a2 N0 [- \0 m        4 D( `3 l, `6 z! T. s
end;" z# Z" Q% Z1 I( I
6 g3 q6 A+ f  k  ]2 k
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~% ~$ p; j. R4 p8 n" x
6 p% a* s4 o! A9 o$ `3 t8 r! E9 B
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-21 15:34 , Processed in 0.015870 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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