python如何读取dbf文件_python2.7读取dbf文件的正确姿势

dbf是一种特殊的文件格式!表示数据库文件,Foxbase,Dbase,Visual FoxPro等数据库处理系统所产生的数据库文件!

DBF 数据库是常用的桌面型数据库,它曾经被各企业、事业单位广泛使用。现在,虽然已经有了很多的各种各样的小、中、大型数据库,DBF 数据库依然被很多单位用于数据交换。

如下图所示就是一个dbf文件的内容通过foxpro打开后的样子:

那么使用python2.7如何把这些dbf文件读取并打印出来呢?

那么就需要使用到核心库dbfread,你需要预先安装一下这个包。

然后还有一个比较常见的问题,那就是如果路径包含了中文,要如何实现编码的正确读取呢?如果我想要灵活的存放文件的位置,读取python文件所在文件夹下的dbf文件呢?

如下代码可能可以帮到你:

#coding: utf8

# python2.7读取dbf文件演示

#导入模块

import sys

reload(sys)

sys.setdefaultencoding('utf8')

import dbfread

'''

注意点:sys.path[0]返回的默认是gbk,需要先解码再编码成utf8才可以。

而s默认是utf8格式的,就不用改了,注意,定义s的时候一定要在前面写上u,然后路径的\需要用\\来转义。

这样才能组装成正确的中文路径!

sys.path[0].decode('gbk').encode('utf8')返回的是当前py文件所在目录。

如果需要动态获取路径,然后取同目录下中文文件夹下的dbf文件就这样组装就可以了。

'''

s = u'\\python文件同目录下中文文件夹名\\xxx.dbf'

spath = sys.path[0].decode('gbk').encode('utf8') + s

print "访问的路径为:" + spath

# 数据表文件名

table = dbfread.DBF(spath)

# 读取列名

for i in table.field_names:

print i,

print ""

# 遍历数据表中(没加删除标志)的记录

for record in table:

for field in record:

print record[field],

print ""

# print的结尾是默认换行的,如果不需要换行则在结尾加“,”,这里展现的效果是同一行的数据打印在同一行,打印完一行换一行

print("*" * 40)

感谢大家的收看,我们下期再见!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值