powerbuilder:在powerbuilder中向Excel传递数据

    PowerBuilder是面向对象数据库开发工具的它可以操纵很多大型数据库和桌面数据库但它对中国式报表打印不太方便而 Excel对此却非常容易若把两者结合起来使用则可取长补短

  建立个Excel工作表如图1以mxz.xls为文件名保存  

  然后编写脚本如下并执行:

  long handle_1

  handle_1=openchannel(″excel″,″mxz.xls″) //建立和Excel通道

  remote(″r2c1″,″序号″,″excel″,″mxz.xls″)

  remote(″r2c2″,″摘要″,″excel″,″mxz.xls″)

  remote(″r2c3″,″收入″,″excel″,″mxz.xls″)

  remote(″r2c4″,″支出″,″excel″,″mxz.xls″)

  remote(″r2c5″,″余额″,″excel″,″mxz.xls″)

  remote(″r2c6″,″日期″,″excel″,″mxz.xls″)

  execremote(″[Save]″,″excel″,″xmk.xls″)

  上述脚本执行后再打开mxz.xls它变成了如图2模样:

  其实这段脚本用到了 3个DDE客户:OpenChannel、SetRemote和ExecRemote其实掌握了这 3个DDE就可以随心所欲地写出打印功能十分强大PowerBuilder数据库

  、OpenChannel   它功能是打开连接DDE服务器通道

  语法   OpenChannel ( applname, topicname {, windowhandle } )

  参数 applname:类型指定DDE服务器应用DDE名称

  topicname:类型指定命令中要使用DDE应用数据或例子

  windowhandle:long类型可选项指明用作DDE客户PowerBuilder窗口窗口句柄省略该参数时当前应用中活动窗口用作DDE客户  

 返回值 long类型执行成功时返回个正数作为已打开通道句柄发生时返回下述值的:   -1打开失败  

-9句柄为NULL   

举例: 下面代码建立到ExcelDDE通道的后请求 3个单元格数据并把这些数据保存在s_regiondata中DDE会话客户端窗口为w_ddewin:

long handle   

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))   

2、SetRemote   功能是请求服务器应用把指定项设置为指定值有两种语法格式下面分别予以介绍:  

 语法请求DDE服务器应用接收保存在指定位置数据该格式不要求事先打开通道适用于仅发出少数几个请求情况

  SetRemote ( location, value, applname, topicname )

  参数   

location:类型指明要DDE服务器部分接收数据位置表达方式由具体DDE服务器决定   

value:类型变量指定发送给DDE服务器数据

applname:类型指定DDE服务器应用DDE名称   

topicname:类型指定要接收数据DDE应用数据或例子   

返回值   eger类型执行成功时返回1发生时返回下述值的:

  -1未启动连接

  -2请求被拒绝

如果任何参数值为NULLSetRemote返回NULL  

 举例:下面代码请求Excel把工作表SALES.XLS第5行第8列单元值设置为5500:

  SetRemote(″R5C8″, ″5500″, ″Excel″, ″SALES.XLS″)  

 语法 2请求DDE服务器应用接收保存在指定位置数据该格式适用于热连接情况即应用已经和服务器建立通道   

SetRemote ( location, value, handle {, windowhandle } )   参数  

 location:类型指明要DDE服务器部分接收数据位置表达方式由具体DDE服务器决定   value:类型变量指定发送给DDE服务器数据  

 handle:long类型指定使用DDE通道句柄  

 windowhandle:long类型可选项指明用做DDE客户PowerBuilder窗口窗口句柄省略该参数时当前应用中活动窗口用做DDE客户   

返回值   eger类型执行成功时返回1发生时返回下述值的:

  -1未启动连接   

-2请求被拒绝

-9 Handle参数值为NULL

  举例:下面代码先打开个通道然后请求Excel将第5行第8列单元值设置为5500:

  long hand   

lehandle = OpenChannel(″Excel″, ″REGION.XLS″)   

SetRemote(″R5C8″, ″5500″, handle)   

3、ExecRemote  

 它功能是请求DDE服务器应用执行命令也有两种语法格式下面分别予以介绍

  语法直接向DDE服务器应用发送条命令(冷连接方式);

  ExecRemote ( command, applname, topicname )   

参数   

command:类型其值为希望DDE服务器应用执行命令命令格式和语法需要参看DDE服务器应用文档applname:类型指定服务器应用DDE名称   

topicname:类型指定命令中要使用DDE应用数据或例子返回值Integer执行成功时返回1发生时返回下述值的:   

-1未启动连接   

-2请求被拒绝

-3不能终止服务器   

如果任何参数值为NULLExecRemote返回NULL   

举例:下面语句请求Excel将活动工作表内容保存到文件REGION.XLS中:

  ExecRemote(″[Save]″, ″Excel″, ″REGION.XLS″)   

语法 2应用打开某个通道后向DDE服务器应用发送命令(热连接方式)   

ExecRemote ( command, handle {, windowhandle } )   

参数   

command:类型其值为希望DDE服务器应用执行命令命令格式和语法需要参看DDE服务器应用文档 handle:long类型指定使用DDE通道句柄   

windowhandle:long类型可选项指明用做DDE客户PowerBuilder窗口窗口句柄省略该参数时当前应用中活动窗口用做DDE客户返回值eger执行成功时返回1发生时返回下述值的:  

-1未启动连接  

-2请求被拒绝

-9handle参数值为NULL   

(新疆 尚建军) 
Tags:  powerbuilder是什么 powerbuilder9.0 powerbuilder powerbuilder

延伸阅读

最新评论

发表评论