取DBF的部分值生成有格式的TXT

lpchenwei 2008-02-28 10:14:10
我做一个小程序,要把DBF中的一部分数据按一定的格式生成TXT文件,不知道怎么做法,哪位帮说明一下,或者有没有例子。100分哟。
...全文
102 17 打赏 收藏 转发到动态 举报
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
lpchenwei 2008-02-29
  • 打赏
  • 举报
回复
记录就是多,记录大约几千条。

我先按你的思路试一下再说。
wwwwb 2008-02-29
  • 打赏
  • 举报
回复
记录数不多的话,可以用上述代码,用Fopen、FPUTS写入数据,思路差不多
wwwwb 2008-02-29
  • 打赏
  • 举报
回复
示例:
SELECT 编号,名称,类型 FROM aa GROUP BY 编号,名称,类型 INTO CURSOR dd
SELECT dd
i=1
SCAN
ff=""
ff2="地址 联系人 "+CHR(13)+CHR(10)
ff=ff+"编号:"+TRANSFORM(编号)+" 名称 :"+名称+' 类型:'+TRANSFORM(类型)+CHR(13)+CHR(10)
SELECT aa
SELECT * FROM aa into CURSOR dd1 WHERE 名称=dd.名称 AND 编号=dd.编号 AND 类型=dd.类型
SELECT dd1
SCAN
ff2=ff2+TRANSFORM(地址)+' '+TRIM(联系人)+CHR(13)+CHR(10)
ENDSCAN
=STRTOFILE(ff+ff2,'d:\zz\'+PADL(i,2,'0')+'.txt')
i=i+1
ENDSCAN

自行修改格式
lpchenwei 2008-02-29
  • 打赏
  • 举报
回复
记录如下;

编号 名称 类型 地址 联系人
123 计算机 1 1 A
123 计算机 1 2 B
123 计算机 1 3 C
123 计算机 2 1 D
123 计算机 2 2 E
123 计算机 2 3 F
124 物理 1 1 G
124 物理 1 2 H

文件结果:

01.TXT

编号:123 类型:计算机 类型:1
地址 联系人
1 A
2 B
3 C
02.TXT
编号:123 类型:计算机 类型:2
地址 联系人
1 D
2 E
3 F
03.TXT
编号:124 类型:物理 类型:1
地址 联系人
1 G
2 H

以上就是我要生成的TXT文件,我现在没有找到一个很好的方法来处理。
wwwwb 2008-02-29
  • 打赏
  • 举报
回复
1、临时表、工作表均可;
2、将记录及正确结果贴出来看看
lpchenwei 2008-02-29
  • 打赏
  • 举报
回复
你所说的新增一字段,是新生成的一个表嘛??还是就在原文件上,
十豆三 2008-02-29
  • 打赏
  • 举报
回复
创建文本很容易,不过要什么格式,就需要不同的代码。

最好帖出你的例子要求,然后大家给出相应的代码。
lpchenwei 2008-02-29
  • 打赏
  • 举报
回复
有没有写好的例子,发给我,我分析一下,我还是没有搞懂.
wwwwb 2008-02-29
  • 打赏
  • 举报
回复
只要你设定了条件可以区分, OR 有标志字段
wwwwb 2008-02-29
  • 打赏
  • 举报
回复
也可以,

也就是DBF中的几条记录生成一个文件
执行完REPL ALL 字段 WITH 你的内容,可以按一定格式转换 后,
COPY TO TT。TXT SDF FOR 条件

用循环也可以
lpchenwei 2008-02-29
  • 打赏
  • 举报
回复
我要把DBF里面的数据读出来,根据数据的不同,生成若干个TXT文件,也就是DBF中的几条记录生成一个文件,另外几条记录又生成另外的一个文件,一共有几十个TXT文件.
wwwwb 2008-02-29
  • 打赏
  • 举报
回复
上述方法是最简单的,也可以创建、打开TXT文件,将内容按一定格式写入,速度较慢
wwwwb 2008-02-29
  • 打赏
  • 举报
回复
新增一字段字符型,用来装内容,
REPL ALL 字段 WITH 你的内容,可以按一定格式转换
再用COPY TO TT。TXT SDF即可
十豆三 2008-02-29
  • 打赏
  • 举报
回复
--假设字段均为字符型

use 表名
index on 编号,名称,类型 to ls &&防止相同编号,名称,类型的记录不连续
go top
store '' to lcBh,lcMc,lcLx
store 0 to i,j
scan
if alltrim(编号)<>lcBh or alltrim(名称)<>lcMc or alltrim(类型)<>lcLX
j=0
endif
if j=0
if i>0
strtofile(lcStr,padl(i,2,'0')+'.txt')
endif
lcStr=''
lcStr='编号:'+alltrim(编号)+chr(9)+'名称:'+alltrim(名称)+chr(9)+'类型:'+alltrim(类型)+chr(13)+chr(10)+chr(9)+'地址'+chr(9)+'联系人'+chr(13)+chr(10)
j=j+1
i=i+1
else
lcStr=lcStr+chr(9)+alltrim(地址)+chr(9)+alltrim(联系人)+chr(13)+chr(10)
endif
lcBh=alltrim(编号)
lcMc=alltrim(名称)
lcLx=alltrim(类型)
endscan
lpchenwei 2008-02-28
  • 打赏
  • 举报
回复
实际上就是vfp控制TXT的问题,在网上打到一些,但都没有创建TXT文件的函数,只有打开的,读取,不全。想找一个比较全的,写这个程序又要用到它。
liuyann 2008-02-28
  • 打赏
  • 举报
回复

帮顶一下。
== 思想重于技巧 ==
lpchenwei 2008-02-28
  • 打赏
  • 举报
回复
没人回答嘛,自己先顶一下。
网管教程 从入门到精通软件篇 ★一。★详细的xp修复控制台命令和用法!!! 放入xp(2000)的光盘,安装时候选R,修复! Windows XP(包括 Windows 2000)的控制台命令是在系统出现一些意外情况下的一种非常有效的诊断和测试以及恢复系统功能的工具。小编的确一直都想把这方面的命令做个总结,这次辛苦老范给我们整理了这份实用的秘笈。   Bootcfg   bootcfg 命令启动配置和故障恢复(对于大多数计算机,即 boot.ini 文件)。   含有下列参数的 bootcfg 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 bootcfg 命令。   用法:   bootcfg /default  设置默认引导项。   bootcfg /add    向引导列表中添加 Windows 安装。   bootcfg /rebuild  重复全部 Windows 安装过程并允许用户选择要添加的内容。   注意:使用 bootcfg /rebuild 之前,应先通过 bootcfg /copy 命令备份 boot.ini 文件。   bootcfg /scan    扫描用于 Windows 安装的所有磁盘并显示结果。   注意:这些结果被静态存储,并用于本次会话。如果在本次会话期间磁盘配置发生变化,为获得更新的扫描,必须先重新启动计算机,然后再次扫描磁盘。   bootcfg /list   列出引导列表中已有的条目。   bootcfg /disableredirect 在启动引导程序中禁用重定向。   bootcfg /redirect [ PortBaudRrate] |[ useBiosSettings]   在启动引导程序中通过指定配置启用重定向。   范例: bootcfg /redirect com1 115200 bootcfg /redirect useBiosSettings   hkdsk   创建并显示磁盘的状态报告。Chkdsk 命令还可列出并纠正磁盘上的错误。   含有下列参数的 chkdsk 命令仅在使用故障恢复控制台时才可用。可在命令提示符下使用带有不同参数的 chkdsk 命令。   vol [drive:] [ chkdsk [drive:] [/p] [/r]   参数  无   如果不带任何参数,chkdsk 将显示当前驱动器中的磁盘状态。 drive: 指定要 chkdsk 检查的驱动器。 /p   即使驱动器不在 chkdsk 的检查范围内,也执行彻底检查。该参数不对驱动器做任何更改。 /r   找到坏扇区并恢复可读的信息。隐含着 /p 参数。   注意 Chkdsk 命令需要 Autochk.exe 文件。如果不能在启动目录(默认为 %systemroot%System32)中找到该文件,将试着在 Windows 安装 CD 中找到它。如果有多引导系统的计算机,必须保证是在包含 Windows 的驱动器上使用该命令。 Diskpart   创建和删除硬盘驱动器上的分区。diskpart 命令仅在使用故障恢复控制台时才可用。   diskpart [ /add |/delete] [device_name |drive_name |partition_name] [size]   参数 无   如果不带任何参数,diskpart 命令将启动 diskpart 的 Windows 字符模式版本。   /add   创建新的分区。   /delete   删除现有分区。   device_name   要创建或删除分区的设备。设备名称可从 map 命令的输出获得。例如,设备名称:   DeviceHardDisk0   drive_name   以驱动器号表示的待删除分区。仅与 /delete 同时使用。以下是驱动器名称的范例:   D:   partition_name   以分区名称表示的待删除分区。可代替 drive_name 使用。仅与 /delete 同时使用。以下是分区名称的范例:   DeviceHardDisk0Partition1    大小   要创建的分区大小,以兆字节 (MB)表示。仅与 /add 同时使用。   范例   下例将删除分区: diskpart /delete Device HardDisk0 Partition3 diskpart /delete F:   下例将在硬盘上添加一个 20 MB 的分区:   diskpart /add Device HardDisk0 20   Fixboot

2,722

社区成员

发帖
与我相关
我的任务
社区描述
VFP,是Microsoft公司推出的数据库开发软件,用它来开发数据库,既简单又方便。
社区管理员
  • VFP社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧