设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 5418|回复: 7

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

  [复制链接]
发表于 2012-3-28 22:25:21 | 显示全部楼层 |阅读模式
小妹想通过 plant simulation 的命令控制相关的excel 文件的行为。但是一直被说语句错误。。。我是这样写的:3 s; X% L1 G1 Z' _- U" ]- i1 E
kanal:= DDEConnect("Excel", "Cost");. w# M' S6 w" d0 A* W+ ~; G2 g
DDEExecute(kanal,"Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value", 1000);8 T4 \# c3 c7 G9 G
DDEExecute(kanal,"Worksheets("Cost").Range("B121").Value = 35", 1000);
0 n7 G8 U7 r2 Z4 h6 vDDEDisconnect(kanal);
* g+ ^  Y) D8 x" F( W5 f系统一直报错,说语法有错。。。excecute 语句里的 cost那里有问题。。。。
! a: |1 R: i! X9 }( L0 m
% R1 e: b6 l/ Q请高手们不吝赐教~~小妹先谢过了~~~~
 楼主| 发表于 2012-3-29 16:43:02 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 17:47 编辑 : R" a7 g- v  g$ @% @
  t$ q! a* M2 |# C+ f- j# e

1 X( ?3 I: K" j; n' M木有人理我么?7 n. _# Z) g( K3 r& {( [. T  i& M$ y  o

0 ]/ x0 _& X; c4 l我去理解了一下系统的报错。。。我觉得是因为系统把头两个引号看作了一对,导致 "Worksheets(" 成了输出的command,而后面那一串电脑就自然不认识了。。。。所以我就试着用中括号把command整个给括起来~写成了这样:
  D, t. W4 Y8 ?, v; c( |
) v& r9 a" p; [; C: i* q: NDDEExecute(kanal,"[Worksheets("Cost").Range("B129").Value = Worksheets("Cost").Range("G31").Value]", 1000);
" ?) Q; Y& s. |2 {% ]  j
, K3 S/ N# T& z但是还是不行~~~有没有高人能给我指点一下~~我应该用一个什么方法把这样的command输入excel??
 楼主| 发表于 2012-3-29 17:48:15 | 显示全部楼层
 楼主| 发表于 2012-3-29 21:57:39 | 显示全部楼层
taoyifei2000 发表于 2012-3-29 21:37 , g7 R+ n& J  z$ m& N4 ]) [
dde确实没用过,不过之前用过其它接口,不知道有没有共性。
6 ]* P( Z% y7 u0 x2 o7 G. }% }; }* T/ K* D; F8 X) u5 T
触发语句是这样写的execute("        'cost'   ...
- E  ?4 X, z6 D& i
谢谢你~~我试了~~不报错也不执行。。。电脑沉默了。。。
 楼主| 发表于 2012-3-29 22:03:28 | 显示全部楼层
本帖最后由 若叶繁茂 于 2012-3-29 22:10 编辑 8 Y0 c. }) n  j" v5 Z. I# l  H
taoyifei2000 发表于 2012-3-29 21:37
, Y6 }, ^5 E) m" g2 |. Z* J* Gdde确实没用过,不过之前用过其它接口,不知道有没有共性。9 {8 j9 e# ]5 }! F& P5 i

# R6 i1 F% L" _触发语句是这样写的execute("        'cost'   ...
4 u# V# t$ q" k9 X" a8 [4 o
4 i% R: E" U) k' Q$ y
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde的热键连上。。。不知道这样行不行~~我去试试。。
7 B6 R+ d$ B' [. ^* s- ^3 M
, _' M; n6 n' m4 [" [& }诶不对阿。。。连热键是单纯的传数据啊。。。。哎呀。。。就结了。。。
发表于 2012-3-29 23:13:45 | 显示全部楼层
本帖最后由 五五 于 2012-3-29 23:16 编辑
9 D) v- n0 _, }4 I4 j
若叶繁茂 发表于 2012-3-29 22:03 5 z- |% [7 F" M) r+ z* \  o
不过我又想了一个办法。。。我可以直接在plant simulation里面写表格。。。然后用dde ...

* H1 B4 d4 |) l3 H
8 k7 D5 s  A, 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   X0 B' X; s: b
我也没用过DDE 目前研究中。。。不过如果你不嫌麻烦 可以用ActiveX操作excel表格的。。。我都是这么干的  ...

6 O+ i* g: ^; B1 m* |谢谢~~前两天突然不能回贴。。。今天发现我的邮箱没激活。。。好奇怪。。。
1 A# q( \6 q7 E4 R$ I  k4 L5 S: j) n9 g- U
我想向你详细请教一下activeX 的execute语句。。。我的目的是指挥excel运行一个宏。. k8 x5 [( ]+ p) S' b
按照plant simulation自带的例子拖了一个activeX控件和一个link到我的network里面来。并且控件已改成了 excel.application。link 跟我的excel文件已经连接。于是我写了:2 f# V# v7 e! q( p) ~/ U
is
; ?: X9 C9 G# f0 _% l( A9 ~        xl: any;7 {4 O8 K# v7 |$ Q9 I
do
% o# ^. j0 v  @7 z6 z7 O7 Z        if ActiveX.active then/ _0 k" Y- G6 q1 L  I
                xl:= activex.application;( Q1 o, N6 }; I# H) M  y4 `
                xl.call ("Macro_Reset");4 L. v* @* [' [6 _0 G
                activex.active:= false;3 }6 ?. A2 i# I, ?' q+ W
        end;, x7 c) F, E' r. I, C
       
% k% K% F" l6 k7 T! d- p0 wend;/ f$ }/ s- t( w& ~# ^

! o6 B, N5 K1 e- o) {显然plant simulation 不认识 xl.call ("Macro_Reset"); 这句话。你之前有提到过一个activeX 的execute的语句~我在帮助里面木有找到,所以还是想问问~~
4 T( d: C  b0 q$ r" r  A- m; |3 s3 s' A
期待你的恢复~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-5-7 12:02 , Processed in 0.014016 second(s), 14 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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