在powerbuilder中向Excel传递数据.docVIP

  • 9
  • 0
  • 约3.46千字
  • 约 7页
  • 2018-01-03 发布于河南
  • 举报
在powerbuilder中向Excel传递数据

在powerbuilder中向Excel传递数据 在powerbuilder中向Excel传递数据 PowerBuilder是面向对象的数据库开发工具之一,它可以操纵很多大型数据库和桌面数据库,但它对中国式报表打印不太方便,而 Excel对此却非常容易,若把两者结合起来使用则可取长补短。   建立一个Excel工作表如图1,以mxz.xls为文件名保存。     然后编写脚本如下并执行:   long handle_1   handle_1=openchannel(″excel″,″mxz.xls″) //建立与Excel的通道   setremote(″r2c1″,″序号″,″excel″,″mxz.xls″)   setremote(″r2c2″,″摘要″,″excel″,″mxz.xls″)   setremote(″r2c3″,″收入″,″excel″,″mxz.xls″)   setremote(″r2c4″,″支出″,″excel″,″mxz.xls″)   setremote(″r2c5″,″余额″,″excel″,″mxz.xls″)   setremote(″r2c6″,″日期″,″excel″,″mxz.xls″)   execremote(″[Save()]″,″excel″,″xmk.xls″)   上述脚本执行后,再打开mxz.xls,它变成了如图2的模样:   其实,这段脚本用到了三个DDE客户函数:OpenChannel()、SetRemote()和ExecRemote(),其实,掌握了这三个DDE函数,就可以随心所欲地写出打印功能十分强大的PowerBuilder数据库程序来。   一、OpenChannel()   它的功能是打开连接DDE服务器的通道。   语法   OpenChannel ( applname, topicname {, windowhandle } )   参数 applname:string类型,指定DDE服务器应用的DDE名称。   topicname:string类型,指定命令中要使用的DDE应用的数据或实例。   windowhandle:long类型,可选项,指明用作DDE客户的PowerBuilder窗口的窗口句柄。省略该参数时,当前应用中的活动窗口用作DDE客户。    返回值 long类型。函数执行成功时返回一个正数作为已打开通道的句柄,发生错误时返回下述值之一:   -1打开失败。   -9句柄为NULL。    示例: 下面的代码建立到Excel的DDE通道,之后请求三个单元格的数据,并把这些数据保存在数组s_regiondata中。DDE会话的客户端窗口为w_ddewin: long handle    string s_regiondata[3] handle = OpenChannel(″Excel″, ″REGION.XLS″, Handle(w_ddewin)) GetRemote(″R1C2″, s_regiondata[1], handle, Handle(w_ddewin))    GetRemote(″R1C3″, s_regiondata[2], handle, Handle(w_ddewin)) GetRemote(″R1C4″, s_regiondata[3], handle, Handle(w_ddewin)) CloseChannel(handle, Handle(w_ddewin))    二、SetRemote()   功能是请求服务器应用把指定项设置为指定值。该函数有两种语法格式,下面分别予以介绍:    语法一,请求DDE服务器应用接收保存在指定位置的数据,该格式不要求事先打开通道,适用于仅发出少数几个请求的情况。   SetRemote ( location, value, applname, topicname )   参数    location:string类型,指明要DDE服务器的哪一部分接收数据,位置的表达方式由具体的DDE服务器决定。    value:string类型变量,指定发送给DDE服务器的数据。 applname:string类型,指定DDE服务器应用的DDE名称。    topicname:string类型,指定要接收数据的DDE应用的数据或实例。    返回值   integer类型。函数执行成功时返回1,发生错误时返回下述值之一:   -1未启动连接。   -2请求被拒绝, 如果任何参数的值为NULL,SetRemote()函数返回NULL。    示例:下面的代码请求Excel把工作表SALES.XLS的第5行第8列单元的值设置为5500:  

文档评论(0)

1亿VIP精品文档

相关文档