hur.cn - 华软网

 热门搜索

100分跪求PB做的动态报表源码

  作者:未知    来源:网络    更新时间:2019/4/16
自己属初学pb之菜鸟,跪求PB做的动态报表源码,不知哪位高人有珍藏,能否给发一份,不甚谢谢感动!!我的邮箱:ducklin825@163.com
------华软网友回答------
发的帖子还很多啊.
------华软网友回复------
有个致用5。0的,要不要?
------华软网友回复------
帮顶
------华软网友回复------
jf
------华软网友回复------
源码给偶也发一份xueru9999@163.com 谢谢
------华软网友回复------
好多,却又没有一个至善至美的,网上也有好多例子,lz能够先百度 一下看看。
------华软网友回复------
  class="deleted_message"> 该回复被版主删除
------华软网友回复------
我也想要,多谢,qiangmeng2003@163.com
------华软网友回复------
动态创建数据窗原理及实现 


动态创建数据窗原理及实现 

在实际应用中,经常需要根据用户需求来动态创建数据窗,一般方法是这样的。

在一个window中加入一个数据窗控件,如dw_new,然则该数据窗没有data object,(空白的)
就能够用以下语法来创建:
dw_new.create(ls_syntax,ls_error) // 创建语法,毛病信息
ls_syntax能够用以下三种方法来形成:

(一)、动态由sql语法创建:

// 连接到pb的example数据库
string ls_sql,ls_syntax,ls_error
ls_syntax = 'select * from department'
ls_syntax = sqlca.SyntaxFromSQL(ls_sql,'style(type=grid)',ls_error)
if len(ls_error) >0 then
    messagebox('Error','SyntaxFromSQL Error:~r'+ls_error)
else
    dw_new.create(ls_syntax,ls_error)
        if len(ls_error) >0 then
            MessageBox("Error", "Create have these errors: ~r" + ls_error)
        else
            dw_new.settransobject(sqlca)
            dw_new.retrieve()
        end if
end if


////////////////////////////////////////////////////////////////////////////////////////////////////////

DataWindow dw
dw=Create DataWindow 
string lssqlstr,lsdwsyntax,lserr,lserrc
//Select…As…的As可将列题目显示为As之后的字符,较为灵活方便。
//可根据实际情况设计生成Select语句及Where子句的可视化界面
lsSQLstr="Select * From people "
lsDwsyntax=SQLCA.SyntaxFromSQL(lsSQLstr,"style(type=Grid)",lserr) //构造SyntaxFromSQL()函数
If Len(lserr)>0 Then
//如果构造SyntaxFromSQL()函数失利,则显示毛病信息并退出
messagebox("毛病信息!",lserr)
Return
end if
dw_1.Create(lsDwsyntax,lserrC) //创建动态数据窗口dw_1
If Len(lserrC)>0 Then
//如果创建动态数据窗口dw_1失利,则显示毛病信息并退出
messagebox("毛病信息!",lserrC)
Return
end if
//为dw_1分配事务对象SQLCA
dw_1.SetTransObject(SQLCA)
//提取数据
dw_1.Retrieve() 


////////////////////////////////////////////////////////////////////////////////////////////////////////

 


(二)、由另一个数据窗的syntax来创建

string ls_syntax,ls_error
ls_syntax = dw_test.describe('datawindow.syntax')
dw_new.create(ls_syntax,ls_error)
if ls_error <> '' then
    messagebox('Create Error',ls_error)
else
    dw_new.settransobject(sqlca)
    dw_new.retrieve()
end if

(三)、读取psr资料来创建

样例
string ls_syntax,ls_error,ls_ret
ls_ret = char(13)+char(10) //回车键
int li_fileNum
long li_length
li_FileNum = FileOpen("efef.psr",Streammode!, read!, shared!, Replace!)

// 以下是pb5的代码
if li_filenum >0 then
    FileSeek(li_FileNum, 158, FromBeginning!)
    li_length = fileRead(li_filenum,ls_syntax)
end if
fileclose(li_filenum)
if li_length = 0 then return
ls_syntax = "release 5;"+ls_ret+ls_syntax 

//截掉ls_syntax中的数据部份,5.0以"sparse(names="dept_name?)  "作为参照位置
//6.0以html(作为参照位置

long  pos1,pos2
pos1 = pos(ls_syntax,'sparse(names="',1)
pos2 = pos(ls_syntax,'"',pos1 +16)
ls_syntax = left(ls_syntax,pos1) + mid(ls_syntax,pos1 +1,pos2 - pos1 +1)

dw_New.create(ls_syntax,ls_error)

if ls_error <> '' then
    messagebox('Create Error',ls_error)
else
    dw_new.settransobject(sqlca)
    dw_new.retrieve()
end if

//pb6,pb7的代码能够参照pb5自己写,只是资料头和数据窗结束标志不同而已。


流方
2000/05/09

 
 PB中运用Web Browser控件步骤:
在pb的某窗口中加入OLE对象,选择Insert control(插入控件),然后选中"Microsoft WEB 浏览器",就能够在这个窗口直接运用IE浏览器控件了。

经常运用函数:(对这个ole控件取名叫ole_web)
ole_web.object.navigate(string ls_url) //浏览某url
ole_web.object.goback() //回退
ole_web.object.goforward() //前进

经常运用事件:
documentcomplete : url请求的页面完成

经常运用属性:
ole_web.object.width
ole_web.object.height

详细的属性,函数、事件能够参照PB中的 browser 工具中的ole对象观察来获得。 


------华软网友回复------
是那个家伙最先在题目上用“跪求”的啊!
BS!
------华软网友回复------
源码给偶也发一份fxbdhyg@163.com 谢谢      
华软声明:本内容来自网络,如有侵犯您版权请来信指出,本站立即删除。