文章分类 | 推荐文章 | 最新文章 | 热点文章 | 最新软件 | 精品软件 | 下载排行 | 推荐下载 | 免费看大片 | WPS | 杀毒软件
清风网络
首 页 软件下载 网络学院 数码学院
QQ 电脑入门 游戏 操作系统 图形处理 办公软件 媒体动画 精文荟萃 工具软件 网络编程 程序开发 网络技术 认证考试 网站建设 文章专栏
当前位置:清风网络学院程序开发PowerBuilder在powerbuilder中向Excel传递数据
精品推荐
特别推荐
·PowerBuilder实用技巧八则
热点TOP10
·PowerBuilder简介
·在PB中用OLE存取blob类型数据
·在PB中如何实现数据模糊查询
·使用XML技术实现OWC对数据库的展示
·PowerBuilder数据录入同步显示
·导出数据到Excel概述
·PB动态报表格式自由定义的实现
·PB程序中在普通激光打印机上实现条码打印
·PB应用ODBC访问不同数据库
·利用PB数据窗口特征制作进度条
·PowerBuilder应用开发系列讲座(6)
·PB8.0应用程序编译发布技术研究
·PB代码优化
·在PB中用Flash制作Splash封面
·PowerBuilder应用开发系列讲座(39)
·在pb中用语音读金额
·PowerBuilder的数据窗口
·Direct3D9初级教程
·关于PB播放AVI文件的补充
·在PowerBulider中读写IC卡

在powerbuilder中向Excel传递数据

日期:2007年5月2日 作者: 查看:[大字体 中字体 小字体]



    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:

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

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

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

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

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

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

返回值   integer类型。函数执行成功时返回1,发生错误时返回下述值之一:

  -1未启动连接。   

-2请求被拒绝。

-9 Handle参数的值为NULL。

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

  long hand   

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

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

三、ExecRemote()  

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

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

  ExecRemote ( command, applname, topicname )   

参数   

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

topicname:string类型,指定命令中要使用的DDE应用的数据或实例返回值Integer。函数执行成功时返回1,发生错误时返回下述值之一:   

-1未启动连接。   

-2请求被拒绝。

-3不能终止服务器。   

如果任何参数的值为NULL,ExecRemote()函数返回NULL。   

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

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

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

ExecRemote ( command, handle {, windowhandle } )   

参数   

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

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

-1未启动连接。  

-2请求被拒绝

-9handle参数的值为NULL。   

(新疆 尚建军) 


[1] [2] 下一页 




上一篇:在PowerBulider中读写IC卡

下一篇:在PowerBuilder中利用DataStore实现查询条件的记忆

在powerbuilder中向Excel传递数据 相关文章:
·EasyRecovery 604硬盘数据恢复软件技巧
·Excel密码保护的解除方法与解除原理
·asp.net(C#)海量数据表高效率分页算法(易懂,不使用存储过程)
·为什么EXCEL身份证号码都科学计数法?
·跟我学做Excel XP斜线表头
·C#源码读取excel数据到程序中-SQL SERVER-到dataset中
·SQL2000 数据库安装说明
·SQL数据库完全使用手册
·Visual C++ ADO数据库编程入门
·在Excel中将文本转换为数字的七种方法
在powerbuilder中向Excel传递数据 相关软件:
·中文版Excel 2003实例与技巧
·powerbuilder10.0中文版
·Excel 2003 全能培训教程
·PowerBuilder 8.0 企业正式版
·ACCESS数据库教程 北京大学的ACCESS教程
·Excel 2000
·爆出网站数据库路径
·Excel应用宝典
·逐步精通数据库 sql server 视频教程
·SQL/MYSQL/数据库教程专栏

特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
[打印本页] [关闭窗口] 转载请注明来源:http://www.vipcn.net
| 帮助(?) | 版权声明 | 友情连接 | 关于我们 | 信息发布
Copyright 2007 www.vipcn.net All Rights Reserved. 鄂ICP备05000083号Powered by:viphot