Skip to content

Instantly share code, notes, and snippets.

@bertspaan
Created January 2, 2014 15:28
Show Gist options
  • Save bertspaan/8220892 to your computer and use it in GitHub Desktop.
Save bertspaan/8220892 to your computer and use it in GitHub Desktop.
Python script to convert DBF database file to CSV
#!/usr/bin/python
import csv
from dbfpy import dbf
import os
import sys
filename = sys.argv[1]
if filename.endswith('.dbf'):
print "Converting %s to csv" % filename
csv_fn = filename[:-4]+ ".csv"
with open(csv_fn,'wb') as csvfile:
in_db = dbf.Dbf(filename)
out_csv = csv.writer(csvfile)
names = []
for field in in_db.header.fields:
names.append(field.name)
out_csv.writerow(names)
for rec in in_db:
out_csv.writerow(rec.fieldData)
in_db.close()
print "Done..."
else:
print "Filename does not end with .dbf"
@traut21
Copy link

traut21 commented Aug 8, 2024

thanks, now I know that this script had been written for P 2.7

Your script tells me
print repr(_rec) ^ SyntaxError: invalid syntax

@martinmanzo
Copy link

Last release of dbfpy was in 2015, most certainly it wasn't updated to py3.

If this is only a one time use just install python 2.7.

@traut21
Copy link

traut21 commented Aug 8, 2024

Thanks, I'll give that a try. Yes, it's a one time use where the dbf has too many lines for LibreOffice

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment