如何修复被破坏的VFP表(*.dbf)

如何修复被破坏的VFP表(*.dbf)   
    
  ----目前在我国,有相当一部分正在运行应用程序是用VFP   编写的,由于突然断电、程序非法关闭等原因,经常会导致VFP数据表.DBF文件被破坏,如果数据表被破坏了,用VFP打开数据表.DBF时,会出现"notatable/dbf"错误提示,导致无法用VFP打开。   
  ----首先介绍一下VFP数据表.DBF的文件结构:   
  ----VFP数据表*.DBF的文件结构由头记录和数据记录组成,头记录定义该DBF的结构并包含与该表相关的其它信息。头记录由文件位置0字节开始。   
  ----数据表头部几个关键字节含义如下:(注:表文件中存储整数时低位字节在前)   
  ----字节偏移说明   
  ----0   表文件的版本类型   
  ----1-3   最近更新的日期(YYMMDD)   
  ----4-7   表文件中记录的个数   
  ----8-9   第一条记录的起始位置   
  ----10-11   一条记录的长度(包括删除标记)   
  ----其它字节的具体描述不在此赘述,可以参考有关部门书籍或者程序开头注释部分。   
  ----在实际工作中发现,许多情况下数据表错误都是由于记录个数比实际记录个数大1个,以至于数据表无法用打开。   
  ----主要通过以下两种办法来对数据表进行修复。   
    
  一、用Pctools、NU的Diskedit等工具软件进行恢复:   
    
  ----运行Pctools,选中无法打开的数据表,按E文件进入编辑功能,按F1切换显示模式。   
  ----按F3进行编辑,将开始的第5个字节值减1,按F5存储,然后退出Pctools,启动VFP,   发现被破坏的数据表可以打开使用了。   
  ----由于许多操作者并不一定熟悉如何使用Pctools,因此我建议大家可以用比较熟悉的Excel程序根据下面的步骤来进行数据表的恢复。   
    
  二、用Excel进行恢复。   
    
  ----启动Excel,选择"打开"按钮,出现打开对话框,在打开文件类型中选择dBase文件(*.DBF)文件类型,再选中被破坏的数据表打开,这时不要做更改,只选择"保存"按钮,会出现"另存为"对话框,仍选择以原来文件名保存,会提示"文件已经存在,是否替换已有文件?",选择"是"。   
  ----然后选择"文件"菜单上的"关闭",会出现提示"数据表文件不是Excel格式,要保留修改吗?   
  ----要保存为Excel格式,单击'是',然后在'保存类型'下拉列表框选'Excel工作簿';   
  ----要用现有格式保存并替换原来的文件,单击'是',然后单击'保存';   
  ----要在关闭文件时维持现有格式并不作保存,单击'否'。"   
  ----由于我们并没有对数据表的记录进行改动,只是为了恢复数据表,所以选择最后一项"在关闭文件时维持现有格式并不作保存",因此单击"否",退出Excel。   
  ----启动VFP,再次打开数据表文件,发现数据表文件已可以被打开了,但是观察数据表的结构,会发现数据表结构中的索引不见了,不过数据表的索引文件还存在。我们只需要给数据表Add索引,并选择原来的索引文件Open即可。   
  ----添加索引文件后退出数据表结构设置,并对数据表重新索引一下,就可以继续使用原   来被破坏的数据表了。   
    
  三、如果是VFP6的DBF,那么用VFP8打开试一试。如果是VFP8的DBF,那么用VFP6打开试一试

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值