Visual Foxpro报表打印程序代码

Visual Foxpro报表打印程序代码

  数据库报表程序是经常使用的,现在很多用户都使用报表设计器设计报表,且简单方便;但笔者在工作中遇到要对成百个数据库打印的情况,这些数据库除了字段名不相同外,其他结构信息基本相同,因此笔者就编制了如下的一个通用程序,供同行参考。 
set talk off 
hh1=printstatus() 
set print on 
do while .not.hh1 
 ?/"打印机未准备好,请准备好打印机/" 
 hh1=printstatus() 
enddo 
set talk off 
set device to print 
clear 
a1=getfile(/"dbf/") &&打开打开文件对话框 
use /"&a1/" &&打开指定的文件 
n1=fcount() &&获取打开的库中的字段数 
dimension a(n1) &&定义一个存放字段名的数组 
dimension b(n1) &&定义一个存放字段宽度的数组 
k=1 
do while k<=n1 
 a(k)=field(k) 
 k=k+1 
enddo &&将字段名赋给数组 
w=1 
do while w<=n1  
 b(w)=fsize(a(w)) &&获取字段的长度 
 if b(w)<6 
  b(w)=8 
 else  
  b(w)=b(w)+2 
 endif 
 w=w+1 
enddo  
do while not eof()  
 r1=1 &&显示表头的第一行  
 m=1 
 col1=1 
 do while m<=n1 
  if m=1 
   @r1,col1 say /"┌/"+replicate(/"-/",b(m))  
  else 
   if m=n1 
    @r1,col1 say /"┬/"+replicate(/"-/",b(m))+/"┐/"  
   else 
    @r1,col1 say /"┬/"+replicate(/"-/",b(m)) 
   endif 
  endif 
  col1=col1+b(m) 
  m=m+1 
 enddo 

m=1 &&显示字段名行 
col1=1 
do while m<=n1 
 if m=1 
  @r1+1,col1 say /"∣/"+substr(a(m),1,6)+replicate(/" /",(b(m)-len(a(m)))) 
 else 
  if m=n1 
   @r1+1,col1 say /"∣/"+substr(a(m),1,6)+replicate(/" /",(b(m)-len(substr(a(m),1,6))))+/"∣/"  
  else 
   @r1+1,col1 say /"∣/"+substr(a(m),1,6)+replicate(/" /",(b(m)-len(substr(a(m),1,6))))  
  endif 
 endif 
 col1=col1+b(m) 
 m=m+1 
enddo 
m=1 &&由于字段多,一行不能完全显示整个行,因此分为两行显示字段名行 
col1=1 
do while m<=n1 
 if m=1 
  @r1+2,col1 say /"∣/"+substr(a(m),7)  
 else 
  if m=n1 
   @r1+2,col1 say /"∣/"+substr(a(m),7)+replicate(/" /",(b(m)-len(substr(a(m),7))))+/"∣/"  
  else 
   @r1+2,col1 say /"∣/"+substr(a(m),7)  
  endif 
 endif  [Page]
 col1=col1+b(m) 
 m=m+1 
enddo 
m=1 &&显示字段名下面的一行表格线 
col1=1 
do while m<=n1 
 if m=1 
  @r1+3,col1 say /"├/"+replicate(/"-/",b(m)) 
 else 
  if m=n1 
   @r1+3,col1 say /"┼/"+replicate(/"-/",b(m))+/"┤/" 
  else 
   @r1+3,col1 say /"┼/"+replicate(/"-/",b(m)) 
  endif 
 endif 
 col1=col1+b(m) 
 m=m+1 
enddo 

row1=r1+4 
do while .not.eof() &&每页显示20个记录 
 m=1 &&显示各记录的值  
 col1=1 
 do while m<=n1  
  if type(a(m))=/"C/" 
   if m=1 
    @row1,col1 say /"∣/"+&a(m) 
   else 
    if m=n1 
     @row1,col1 say /"∣/"+alltrim(&a(m))+replicate(/" /",(b(m)-len(alltrim(&a(m)))))+/"∣/" 
    else 
     @row1,col1 say /"∣/"+&a(m) 
    endif 
   endif 
  else 
   if m=1 
    @row1,col1 say /"∣/"+str(&a(m)) 
   else 
    if m=n1 
     @row1,col1 say /"∣/"+alltrim(str(&a(m)))+replicate(/" /",(b(m)-len(alltrim(str(&a(m))))))+/"∣/" 
    else 
     @row1,col1 say /"∣/"+alltrim(str(&a(m))) 
    endif 
   endif  
  endif 
  col1=col1+b(m) 
  m=m+1 
 enddo 
 SKIP 
 if eof() 
  &&显示数据库结束的最后一行 
  m=1 
  col1=1 
  do while m<=n1 
   if m=1 
    @row1+1,col1 say /"└/"+replicate(/"-/",b(m)) 
else 
    if m=n1 
     @row1+1,col1 say /"┴/"+replicate(/"-/",b(m))+/"┘/" 
    else 
     @row1+1,col1 say /"┴/"+replicate(/"-/",b(m)) 
    endif 
   endif 
   col1=col1+b(m) 
   m=m+1 
  enddo 
  h=/".f./" 
  exit 
 else 
  if r1=20 &&显示每一页的最后一行 
   m=1 
   col1=1 
  do while m<=n1 
   if m=1 
    @row1+1,col1 say /"└/"+replicate(/"-/",b(m)) 
   else 
    if m=n1 
     @row1+1,col1 say /"┴/"+replicate(/"-/",b(m))+/"┘/" 
    else 
     @row1+1,col1 say /"┴/"+replicate(/"-/",b(m))  [Page]
    endif 
   endif 
   col1=col1+b(m) 
   m=m+1 
  enddo 
  r1=1 
  eject 
  exit 
 else 
  m=1 &&显示每个记录下面的一行表格线 
  col1=1 
  do while m<=n1 
   if m=1 
    @row1+1,col1 say /"├/"+replicate(/"-/",b(m)) 
   else 
    if m=n1 
     @row1+1,col1 say /"┼/"+replicate(/"-/",b(m))+/"┤/" 
    else 
     @row1+1,col1 say /"┼/"+replicate(/"-/",b(m)) 
    endif 
   endif 
   col1=col1+b(m) 
   m=m+1 
  enddo 
 endif 
 ENDIF 
 row1=row1+2 
 r1=r1+1 
 enddo && 每页显示20个记录到此 
enddo 
set print off 
set device to screen 
set talk on 
return 
  以上程序将一个数据库中的所有记录以行为单位打印出来,编制环境是Visual Foxpro 6.0,如果一个数据库字段比较少,希望一行打印二个以上的记录,稍作修改即可。需要提醒读者的是,由于考虑到篇幅,本程序只设计了包含数字型和字符型的数据库,对有其它类型的数据库,稍作修改就行了;如果用户希望一页的记录不是20,只需要修改if r1=20这句中r1的值。笔者已经编制了这类程序,可以向读者提供。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值