设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4450|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:  m; t0 ^( c. B6 a2 s+ }6 J
kanal:= DDEConnect("Excel", "Cost");: ~3 Y( F) G+ F' o5 R! w
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);* g1 w2 `+ t% l0 `9 [
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);) X: H$ s2 u# Y; l2 V
DDEDisconnect(kanal);0 t# k7 ?  I1 H, B
系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。& `4 S& L1 n+ N! \# {

0 R, O3 L1 `, }请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑
4 T8 r: {# f$ X0 Q; P- i& T# N$ f: `8 e8 g7 u2 u4 k8 N

9 L2 B% P; V) Z9 Z$ E, @木有人理我么?
0 `- H+ G3 j, b2 c) ?" e# r. _4 o7 }9 P7 {4 ^) U. V0 g  ~- @
我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
' Q) ]0 l6 p- Y% f4 N: Y/ x8 m9 Q' ^: m8 \: U
DDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
) r( Q# Y* F7 o2 L3 F/ N4 H. `' {
但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 1 @+ n4 K1 J, A- G2 |3 B9 l; _
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
( p9 J$ ?/ t+ U: [; f5 V3 G
& @. G; ~% ~2 f7 \& q7 {触发语句是这样写的execute("        'cost'   ...

8 ?% h3 A' C: R5 }' X- C+ @谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑
1 w2 Z* S  r4 v9 i5 v8 b
taoyifei2000 发表于 2012-3-29 21:37
/ ~7 E1 ~  t& @' u: S, W" L0 P. Pdde确实没用过,不过之前用过其它接口,不知道有没有共性。
+ F+ a5 U6 p. b5 u
5 R; i' x- g+ B6 b. J& J  z触发语句是这样写的execute("        'cost'   ...

! w8 Q$ g# [0 a$ W; J
& @( I0 \0 _( g( R( m不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。- u( `) e) g6 }+ l, Y8 v* y
! ^# j# C1 r9 G, B
诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
* U3 w% i- q+ u! t  j
若叶繁茂 发表于 2012-3-29 22:03
2 H" k1 c! `$ Q1 S不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...
4 j6 u% }" c- h
) R$ g' e$ M3 R9 M
我也没用过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
  ~* I# P" p$ ]) H& {" z我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...
( E: b# t$ K" w( ~& z" z( n) O$ m
谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
5 l: w5 @  Q7 G  ]/ W9 C* A7 x8 v- A) ]0 g
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。7 E4 d0 [/ V" B* @1 V3 e
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:; W" m% Y" x/ t/ Z
is
  i# s3 ]8 ~  Q- v. w# `1 M        xl: any;
0 o* {7 M$ l, F. Y" I$ f) Ndo
5 Z$ Q# Z7 D3 |        if ActiveX.active then
3 m* y: R8 d8 h                xl:= activex.application;& T8 z: f+ W8 u6 z
                xl.call ("Macro_Reset");
' C1 T" Z3 F6 t2 J                activex.active:= false;
# }( ]! J( s( ~5 Z* `        end;
6 [/ W! L# X( v0 S8 y6 I# t- G        3 j& o" i# t( p( A
end;- \, k0 n! t# t( I7 a
2 k$ B: b; Q3 N- t2 ~0 j- T
显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~/ {# m8 e7 h& Z1 M/ M7 K; O
3 u+ u7 c9 I( m2 m
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-14 12:46 , Processed in 0.016912 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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