Loading... dbf 是一种特殊的文件格式!表示数据库文件,Foxbase,Dbase,Visual FoxPro 等数据库处理系统所产生的数据库文件! DBF 数据库是常用的桌面型数据库,它曾经被各企业、事业单位广泛使用。现在,虽然已经有了很多的各种各样的小、中、大型数据库,DBF 数据库依然被很多单位用于数据交换。 如下图所示就是一个 dbf 文件的内容通过 foxpro 打开后的样子: ![python-dbf-1.jpg](http://static.fox-9.com/uploads/2021/08/15/python-dbf-1.jpg!webp) 那么使用 python 2.7 如何把这些 dbf 文件读取并打印出来呢? 那么就需要使用到核心库 dbfread,你需要预先安装一下这个包。 然后还有一个比较常见的问题,那就是如果路径包含了中文,要如何实现编码的正确读取呢?如果我想要灵活的存放文件的位置,读取 python 文件所在文件夹下的 dbf 文件呢? 如下代码可能可以帮到你: ```python # coding: utf8 # python 2.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) ``` 感谢大家的收看,我们下期再见! 最后修改:2021 年 08 月 15 日 © 允许规范转载 赞 赠人玫瑰,手留余香