网站建设| 数据库类| 图形图象| 程序设计| 现代办公| 操作系统| 考试认证| 网络技术| 软件工程| 电脑相关| 文学作品
网站开发| 网页制作| 操作系统| 图象图形| 考试认证| 数据库类| 程序设计| 硬件技术| 现代办公| 网络技术| 笑话频道
 
您的位置: 电脑书库首页-> 电脑文摘-> 数据库类-> PowerBuilder-> 在powerbuilder中向Excel传递数据

在powerbuilder中向Excel传递数据
作者:佚名 来源:InterNet 加入时间:2005-1-31
相关文章
  • 浅析PowerBuilder下动态SQL语句
  • 在PowerBuilder中调用ChooseColor函数
  • 在powerbuilder中使下拉列表框可以和数据关联
  • PowerBuilder连接Sybase SQL Server的注意事项
  • PowerBuilder编程技巧四则
  • 用Powerbuilder开发WEB数据库
  • 利用POWERBUILDER开发数据库的WEB查询
  • PowerBuilder中实现数据窗口打印预览通用方法
  • 怎样用PowerBuilder开发WEB应用
  • PowerBuilder制作IE风格的图标按钮
  • 相关书籍:
  • PowerBuilder系列讲座
  • PowerBuilder 6.0用户参考手册
  • PowerBuilder 7.0
  • 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。

    [文章录入员:nancy]

    相关文章
  • 浅析PowerBuilder下动态SQL语句
  • 在PowerBuilder中调用ChooseColor函数
  • 在powerbuilder中使下拉列表框可以和数据关联
  • PowerBuilder连接Sybase SQL Server的注意事项
  • PowerBuilder编程技巧四则
  • 用Powerbuilder开发WEB数据库
  • 利用POWERBUILDER开发数据库的WEB查询
  • PowerBuilder中实现数据窗口打印预览通用方法
  • 怎样用PowerBuilder开发WEB应用
  • PowerBuilder制作IE风格的图标按钮
  • 相关书籍:
  • PowerBuilder系列讲座
  • PowerBuilder 6.0用户参考手册
  • PowerBuilder 7.0
  • 本站推荐内容

    近期主机类热搜关键词:
    美国服务器 美国服务器租用 海外服务器租用 国外服务器租用

    PowerBuilder
    ACCESS
    MS SQL
    MySQL
    Oracle
    Foxpro
    PowerBuilder
    Sybase
    其它
    电脑教程阅读排行
    ·浅析PowerBuilder下动...
    ·PowerBuilder连接Sy...
    ·用Powerbuilder开发W...
    ·在powerbuilder中向E...
    ·PB通过OLEObject使用W...
    ·PB中读取地磅BCD解码
    ·在PowerBuilder中操作...
    ·PB动态报表格式自由定义的实现
    ·PB开发Sybase数据库应用技...
    ·如何在PB中制作特殊形状数据窗口...