设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4619|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:; w- E8 E" S( Q
kanal:= DDEConnect("Excel", "Cost");& G7 [5 c0 Q2 r. d* u
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);5 V8 U8 @2 W+ ~3 S( L5 S: I) i& |
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
0 h* o7 l' f3 l3 q7 u8 v* NDDEDisconnect(kanal);. M9 k% N' N9 [/ l% r" C
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。+ j; V$ r* N9 R  A

* X) e8 t2 I2 b请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 ( k) V0 Z" m) ^* V2 ~& m$ S3 P

4 K9 z( e0 g9 c, A5 a2 p  L( x( S6 ?& H/ m( L1 Y
木有人理我么?
3 H) l, ^- ^- `$ m9 J
$ f- u+ P5 I: Y0 [* @4 C) ~! |5 ^我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:" B6 r( w; k7 r" H4 t
% o* Y9 I, `% P7 }4 L6 [
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
! D' @1 {- m$ I$ j2 y+ f) n( s
4 c! B) n, d& h2 B' v1 g但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37
$ c6 c; E. ~+ ~dde确实没用过,不过之前用过其它接口,不知道有没有共性。/ ^5 q( ]9 `- W$ P
; Q9 Z8 y# `; @& Z
触发语句是这样写的execute("        'cost'   ...
! l) ]& {3 W+ k5 n
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
! `( P( T' O8 S3 Q
taoyifei2000 发表于 2012-3-29 21:37 ( G! H$ k9 t' p8 \
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
6 b+ \( h9 f  {# F) Z! H
5 [( J: u2 M2 k1 ~& ^) V触发语句是这样写的execute("        'cost'   ...
* ?1 M' `4 ?! E9 `& ]1 ]

* S, P# {# O7 [! @3 @不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
' w6 l! u- [0 H$ ~  {( h+ O8 ]4 Z& a6 ^* a
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑 ) B7 h- f/ p: O+ Y# V
若叶繁茂 发表于 2012-3-29 22:03 5 z$ @* k) c! _% O4 a
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
2 g8 m, }1 v! O6 `( J# R3 g

$ @2 _+ m- S* i5 i我也没用过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 , M2 z; v9 p7 ^) H4 h
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
. {% {" e. W8 w8 _/ L" H
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。- z1 Z% @( E) d( H9 a3 Y# r

; n; b1 w9 f- K! K4 W3 d1 [! I我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。/ a* I; M5 \9 y) d
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:
- Q; L: F- J& v# ~. m+ i2 I5 D+ dis
3 w6 @; S  }8 [6 f        xl: any;2 |9 x1 U3 r( i3 _3 _! j+ \
do; G1 g. o& Y: @' a( G) y3 |% J
        if ActiveX.active then! T1 O* \" J5 a
                xl:= activex.application;( s' O4 L) v. t/ q  C; |2 K; a3 T
                xl.call ("Macro_Reset");0 }  |$ |3 N( d5 N1 i
                activex.active:= false;
9 |( f" }9 @/ L" J: U; \        end;2 n4 }; Y8 i( l# {- x, Z1 q9 |
       
: J6 ?" z2 N, V/ Q/ f- f8 A: oend;
/ h/ w5 T: p4 U( `6 [2 W6 `- }7 J
/ w, @5 S" S7 E' U显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
+ }9 v3 U% C3 d# ^; K. n5 W) ^! E* r" O' s: V
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-10-17 09:51 , Processed in 0.015488 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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