• 网络学院
  • 新手学堂
  • 操作系统
  • 网络技术
  • 软件应用
  • 办公软件
  • 编程技术
  • 网站架设
  • 数据库类
  • 平面设计
  • 多媒体类
  • 游戏资讯
  • 教学论文
  • 认证考试
Visual
广告位
  站点:
  • 首 页
  • 最新软件
  • 最新文章
  • 国内软件
  • 国外软件
  • 汉化软件
  • 源码下载
  • 字体下载
Visual Foxpro通用报表打印程序
软件发布 Visual Foxpro通用报表打印程序
网络软件 系统工具 应用软件 联络聊天 图形图像 多媒体类 行业软件 游戏娱乐 编程开发 安全相关 教育教学 数码软件
热门软件: QQ 瑞星 pplive e话通 木马克星 千千静听 office2000 五笔字根 Photoshop 视频分割
返回首页 | 文章首页 | 编程技术 | VFP教程 | Visual Foxpro通用报表打印程序

Visual Foxpro通用报表打印程序

 

添加时间: 2007-7-9 3:05:12  作者: VFP教程  阅读次数:340   来源: http://www.d9soft.com

 

 

       

  数据库报表程序是经常使用的,现在很多用户都使用报表设计器设计报表,且简单方便;但笔者在工作中遇到要对成百个数据库打印的情况,这些数据库除了字段名不相同外,其他结构信息基本相同,因此笔者就编制了如下的一个通用程序,供同行参考。

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
 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))
    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的值。笔者已经编制了这类程序,可以向读者提供。

 

 

 

上下文章:

 

上一篇文章: VFP 6.0网络编程应注意的问题 下一篇文章: 在ASP.NET中使用Visual FoxPro7.0

相关文章:

  • AV杀手变种强行关闭杀度软件与下载恶意程序
  • Oracle外部程序的触发小结
  • 开发技术:调查您的应用程序需求
  • Oracle外部程序的触发小结
  • 开发技术:调查您的应用程序需求

相关软件:

  • 华娱网电影程序 v1.0版
  • 武汉娱乐网翻唱程序
  • 极限音乐网全站程序
  • 林州数码港FLASH程序
  • 中国电台网web程序
  • 做好娱乐免费电影程序 v1.0

 

 

快速导航

  • 网络学院
  • 精品汇聚
  • 字体下载
  • 教程下载
  • ASP源码
  • PHP源码
  • Net源码
  • JSP 源码

编程技术分类导航

  • ASP & ASP.NET教程
  • PHP教程
  • JSP教程
  • C/C++教程
  • VB & VB.NET教程
  • VC教程
  • Delphi教程
  • BCB教程
  • VFP教程
  • PB教程
  • JAVA教程
  • XML教程
  • C#教程
  • CGI教程

本类经典文章推荐

  • 在ASP.NET中使用Visual FoxPro7.0
  • Visual Foxpro通用报表打印程序
  • VFP 6.0网络编程应注意的问题
  • VFP应用程序多媒体徽标的实现
  • VFP中多条件数据查询程序的实现
  • 二级FoxBASE上机考试技巧
  • VFP中状态栏控件的使用说明
  • VFP智能感应的二次开发
  • Visual FoxPro 9.0更强大了
  • Visual FoxPro 9中新的数据处理方...

VFP教程阅读排行

  • VFP9.0中设计与使用表单和报表
  • Visual Foxpro通用报表打印程序
  • VFP中多条件数据查询程序的实现
  • VFP 6.0网络编程应注意的问题
  • Visual FoxPro9.0中设计与使用查询
  • Visual FoxPro 9.0更强大了
  • Visual FoxPro成长之路
  • 在ASP.NET中使用Visual FoxPro7.0
  • 二级FoxBASE上机考试技巧
  • Visual FoxPro 9中新的数据处理方...

编程技术阅读总排行

  • VB入门教程之一
  • 第二章 PowerBuilder 入门之创建新...
  • Java连接数据库实例
  • 第一章 什么是PowerBuilder
  • VC++之List Box/Check List Box控...
  • VC++ List Ctrl控件
  • VC++ Combo Box/Combo Box Ex控件
  • 学C++不得不看的一篇文章
  • VB入门教程之二
  • VC++之Button控件

广告位置

字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z 回到顶部

关于我们 | 版权声明 | 免责条款 | 广告联系 | 软件发布 | 下载帮助 | 下载排行 | 网站地图 | 特别鸣谢 | 友情连接

copyright; 2005-2008 D9soft.com 第九软件网 版权所有