- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PowerBuilder_程序.doc
1、PB动态报表的实现
在通常的管理信息系统开发过程中,总是有没完没了的报表需要制作,调试报表花费的时间也是最多而且乏味,还常常不能满足客户的要求。如果能够让用户自己调整报表的格式和内容,然后将它保存下来,程序下次启动
时若能自动调用保存了的报表格式那就方便多了。?实现原理? PowerBuilder中有一种以PSR为后缀的特殊的保存报表的文件格式(本文简称PSR文件),数据窗口可以直接读取PSR文件生成报表,而程序通过生成PSR文件,就可以实现动态报表格式的保存。? 首先,通过设置数据窗口对象(dataobject)中的文本、列等的Resizeable和moveable属性为1来实现对象位置的拖动控制,通过数据窗口的Modify函数实现对象值的更改(包括增加和删除)。? 其次要保存报表格式。在一个应用中,数据窗口对象的名称总是惟一的,将每一个数据窗口对象转化成PSR文件存于数据库表中。在窗口打开时,程序先校验报表格式是否存在。如果存在,将报表格式读出来放在一个临时文件当中,然后设置数据窗口(datawindow)的数据对象(dataobject)为这个报表文件,并提取数据;?如果不存在,直接提取数据即可。?实现过程? 1.?建立一个数据库表用以保存报表格式文件,各个字段定义如下:? 2.?建立一个窗口w_temp。?定义实例变量如下:? string?is_dwtype,is_dwobject? //保存报表中对象的类型及名称? 3.?在窗口的Open事件中加入如下代码,?校验报表格式是否存在,如果存在,读取定义好的报表格式到数据窗口。? blob?emp_pic? long?ll_handle? string?ls_dwobject,ls_reportfile,ls_path? ls_dwobject?=?dw_print.dataobject? //判断是否存在该数据窗口的报表格式? select?count(*)?into:ll_count?from?dyn_report?where?dwobject?=:ls_dwobject;? if?ll_count0?then? //读取报表格式文件到大文本变量? selectblob?memo?into:emp_pic?from?dyn_report?where?dwobject?=:ls_dwobject;? //创建PSR临时文件并保存到硬盘? ls_reportfile?=‘\temp7089.psr’? ll_handle?=?FileOpen(is_reportfile,StreamMode!,write!,LockWrite!,Replace!)? FileWrite(ll_handle,emp_pic)? FileClose(ll_handle)? dw_print.dataobject?=?ls_reportfile? dw_print.settransobject(sqlca) else? Dw_print.settransobject(sqlca)? End?if Dw_print.retrieve()?如何在PB中实现串口编程可以使用mscomm32.ocx控件.
脚本如下: String?ls_data? //使用COM1端口。? ole_1.object.CommPort?=?1? //设置速率为9600,无奇偶校验,8?位数据,一个停止位。? ole_1.object.Settings?=?9600,N,8,1? //读入整个缓冲区的数据。? ole_1.object.InputLen?=?0? 打开端口? ole_1.object.PortOpen?=?True?
//发送attention命令? ole_1.object.Output?=?ATV1Q0?+?char(13)?
//等待数据。? Do? Yield()? //从Com端口取数据? ls_data?+=?ole_1.object.Input? LOOP?Until(Pos(ls_data,?OK?+?char(13)?+?char?(10))??0)?
//向Com端口发送数据使用Output方法? ole_1.Object.Output?=?ls_data?
//关闭端口。? ole_1.object.PortOpen?=?FALSE?
中实现数据窗口动态排序的三种方法
PowerBuilder中使用数据窗口检索到的数据往往是无序的,虽然可以通
您可能关注的文档
- Matlab直线拟合和平面拟合.doc
- matlab节点导纳矩阵示例.doc
- matlab计算.ppt
- Matlab软件包与Logistic回归.doc
- Maya节点.ppt
- MCGSE组态环境.doc
- MCGS之构造实时数据库.doc
- MCGS组态软件介绍.doc
- MC领地指令大全.doc
- MDADAMS虚拟样机从入门到精通学习笔记(绝对比看书更有用).doc
- 浙江省温州市浙南名校联盟2025-2026学年高一上学期期中联考数学试题含解析.docx
- 26高考数学提分秘诀重难点34圆锥曲线中的定点、定值、定直线问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点35概率与统计的综合问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点31圆锥曲线中的切线与切点弦问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点30圆锥曲线中的弦长问题与长度和、差、商、积问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点29巧解圆锥曲线的离心率问题(举一反三专项训练)(全国通用)(含解析).docx
- 26高考数学提分秘诀重难点28直线与圆的综合(举一反三专项训练)(全国通用)(含解析).docx
- 寡核苷酸药物重复给药毒性研究技术指南.docx
- 重组溶瘤腺病毒生产质量管理标准.docx
- 26高考数学提分秘诀重难点27直线与圆中常考的最值与范围问题(举一反三专项训练)(全国通用)(含解析).docx
原创力文档


文档评论(0)