在VB6中导出EXCEL,FOXPRO,PRODOX格式的表 (转)

news/2024/7/24 3:58:56
在VB6中导出EXCEL,FOXPRO,PRODOX格式的表 (转)[@more@]

 

MIS系统在月末由于业务的需要总要汇总当月业务情况,并且导出报盘,我把我的程序中的这一部分功能单拿出来,做成一个小的程序,仅供参考。

一般是在ACCESS或是sqlSERVER中查寻,或是汇总,然后生成一个‘记录集’可以显示在GRID里,也可以将这个记录集导出到磁盘中。

下面可以导出Xls,dbF,DB,MDB(表),这些功能是由ISAM数据库接口实现,为了导出各种版本的文件,我在MS网站下载了最新的JET4和MDAC6。前者到用于桌面数据库如ACCESS,FOXPRO的组件,后者是实现新版本ADO组件。分别在:
DOWNLOAD.microsoft.com/download/Access2000/SP/4.0/NT5/EN-US/Jet40SP5_W2K.exe">http://download.microsoft.com/download/access2000/SP/4.0/NT5/EN-US/Jet40SP5_W2K.exe
win98Me/CN/mdac_typ.exe" rel="nofollow">http://download.microsoft.com/download/dasdk/install/2.60.6526.3/WIN98Me/CN/mdac_typ.exe

这些是标准的SQL导出语句:
select * into [excel 8.0;database=导出目录].导出表名 from 表
select * into [FoxPro 2.6;database=导出目录].导出表名 from 表
select * into [FoxPro 2.5;database=同上].导出表名 from 表
select * into [dbase III;database=同上].导出表名 from 表
select * into [Paradox 4.X;database=同上].导出表名 from 表
select * into [;database=C: empxxx.mdb].导出表名 from 表
下面程序为实现用户自定议文件名用变量代替一部分。
http://go.163.com/~chunpeng/project/export.jpg

http://go.163.com/~chunpeng/project/Export.zip 点这里下载原程序文件。


'请先引用ADODB类库。
Dim Export_Str, mdbTable As String
Dim rsExport As New ADODB.Recordset
Dim conn As New ADODB.Connection
Private Sub Close_cmd_Click()
Unload Me
End Sub

Private Sub EXport_cmd_Click()
Dim myPath, myStr As String, myPos As Integer

'******************处理选择的各种表的导出
With Dialog1
If myOption(2).Value Then
.FilterIndex = 1
.ShowSave
myStr = StrReverse(.FileName) '串取反
myPos = InStr(myStr, "")  '在反字符串中,找从左开始第一个的位置
On Error GoTo myError  '防FILENAME为空,MID出错
myPath = StrReverse(Mid(myStr, myPos)) '取目录部分,并还原.
myStr = StrReverse(Left(myStr, myPos - 1)) '取文件名
Export_Str = "select * into [dBase III;database=" & myPath & "]." & myStr & " from Customers"
.DefaultExt = "*.DBF"

ElseIf myOption(3).Value Then
mdbTable = InputBox("请给导出到MDB文件的表确定表名")
.FilterIndex = 2
.ShowSave
Export_Str = "select * into [;database=" & .FileName & "]." & mdbTable & " from Customers"
.DefaultExt = "*.MDB"

ElseIf myOption(4).Value Then
.FilterIndex = 3
.ShowSave
Export_Str = "select * into [Excel 8.0;database=" & .FileName & "].Customers from Customers"
.DefaultExt = "*.XLS"

ElseIf myOption(5).Value Then
.FilterIndex = 4
.ShowSave
myStr = StrReverse(.FileName) '串取反
myPos = InStr(myStr, "")  '在反字符串中,找从左开始第一个的位置
On Error GoTo myError  '防FILENAME为空,MID出错
myPath = StrReverse(Mid(myStr, myPos)) '取目录部分,并还原.
myStr = StrReverse(Left(myStr, myPos - 1)) '取文件名
Export_Str = "select * into [Paradox 4.X;database=" & myPath & "]." & myStr & " from Customers"
.DefaultExt = "*.DB"
End If
End With

'*****生成文件
Debug.Print Export_Str
If rsExport.State = 1 Then
rsExport.Close
End If

If Dir(Dialog1.FileName) <> "" Then
On Error GoTo myError  '防用户没选文件
  If Dialog1.FilterIndex <> 2 Then
  Kill (Dialog1.FileName)
  End If
rsExport.Open Export_Str, conn, adOpenStatic, adLockOptimistic
Else
rsExport.Open Export_Str, conn, adOpenStatic, adLockOptimistic
End If
myError:
Exit Sub
End Sub

Private Sub Form_Load()
'联接数据库并打开记录集
conn.CursorLocation = adUseServer
conn.Open "PROVideR=Microsoft.Jet.OLEDB.4.0;Data source=" + App.Path + "NWind.mdb;"
rsExport.Open "select *from Customers", conn, adOpenStatic, adLockOptimistic
Set Grid1.DataSource = rsExport

'初始化对话筐
With Dialog1
.Filter = "FoxBase/FoxPro (*.DBF)|*.DBF|Access 8.0(*.MDB)|*.MDB|Excel 8.0(*.XLS)|*.XLS|Paradox 4.x(*.DB)|*.DB"
.DialogTitle = "导出文件为"
.CancelError = False
End With
End Sub

 


 


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10790690/viewspace-953009/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10790690/viewspace-953009/


http://www.niftyadmin.cn/n/805909.html

相关文章

Android窗口管理服务WindowManagerService的简要介绍和学习计划

在前一个系列文章中&#xff0c;我们从个体的角度来分析了Android应用程序窗口的实现框架。事实上&#xff0c;如果我们从整体的角度来看&#xff0c;Android应用程序窗口的 实现要更复杂&#xff0c;因为它们的类型和作用不同&#xff0c;且会相互影响。在Android系统中&#…

绝!2D素材3D效果!

用2D素材实现3D效果!前言好久没写教程笔记了&#xff0c;不知大伙是否想念教程了&#xff1f;温馨提示&#xff1a;所有内容纯属个人瞎玩研究&#xff0c;如要上线项目&#xff0c;请自行评估~ oh最近逛论坛&#xff0c;看到有一位小伙伴想实现下面这种透视效果。预期效果接着&…

【JVM系列】经典垃圾回收器

垃圾回收器 分类 Partial GC&#xff1a;并不收集整个GC堆的模式 Young GC&#xff1a;只收集young gen的GC&#xff0c;有 Serial GC 、ParNew GC、Parallel Scavenge GC。Old GC&#xff1a;只收集old gen的GC。只有 CMS GC 是针对老年代的。Mixed GC&#xff1a;收集整个yo…

Java 文件IO读取工具类

import java.io.*; import java.util.HashSet; import java.util.Iterator; import java.util.Set;public class FileReAndWrUtil {/*** 读取文件* param file* return*/public static Set<String> readFile(File file){Set<String> set new HashSet<>();Fi…

华为OD机试真题 Python 实现【工作安排】【2023Q1 100分】

目录 一、题目描述二、输入描述三、输出描述四、解题思路五、Python算法源码六、效果展示1、输入2、输出3、说明 一、题目描述 小明每周上班都会拿着自己的工作清单&#xff0c;工作清单内包含n项工作&#xff0c;每项工作都有对应的耗时时长&#xff08;单位h&#xff09;和报…

【Hadoop学习】HDFS中的集中化缓存管理

Hadoop版本&#xff1a;2.6.0 本文系从官方文档翻译而来&#xff0c;转载请尊重译者的工作&#xff0c;注明以下链接&#xff1a; http://www.cnblogs.com/zhangningbo/p/4146398.html 概述 HDFS中的集中化缓存管理是一个明确的缓存机制&#xff0c;它允许用户指定要缓存的HDFS…

同一级目录如何表示

当前目录&#xff1a; ./文件名同一级目录&#xff1a; ../文件名上上级目录: ../../文件名下级目录: 目录名/文件名上上级目录: ../../文件名下级目录: 目录名/文件名 从根目录开始&#xff1a; /文件名/文件名

SQL Server性能分析参数 (转)

SQL Server性能分析参数 (转)[more]sql SERVER性能分析参数 关键词&#xff1a;SQL SERVER 当您怀疑计算机硬件是影响SQL Server运行性能的主要原因时&#xff0c;可以通过SQL Server Performance Monitor监视相应硬件的负载&#xff0c;以证实您的猜测并找出系统瓶颈。下文将…