annotate roundup/rcsv.py @ 2041:2add75e296d2 maint-0.6

fixed rego
author Richard Jones <richard@users.sourceforge.net>
date Tue, 24 Feb 2004 21:13:26 +0000
parents d85cb1ad9bc9
children 0afdf96ea9d7 3555941caea0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1778
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
1 """
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
2 Supplies a Python-2.3 Object Craft csv module work-alike to the extent
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
3 needed by Roundup using the Python 2.3 csv module.
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
4
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
5 """
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
6
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
7 from roundup.i18n import _
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
8 error = """Sorry, you need a module compatible with the csv module.
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
9 Either upgrade your Python to 2.3 or later, or get and install
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
10 the csv module from:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
11 http://www.object-craft.com.au/projects/csv/
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
12
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
13 These two csv modules are different but Roundup can use either.
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
14 """
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
15 try:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
16 import csv
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
17 try:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
18 reader = csv.reader
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
19 writer = csv.writer
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
20 excel = csv.excel
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
21 error = ''
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
22 except AttributeError:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
23 # fake it all up using the Object-Craft CSV module
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
24 class excel:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
25 pass
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
26 if hasattr(csv, 'parser'):
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
27 error = ''
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
28 def reader(fileobj, dialect=excel):
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
29 # note real readers take an iterable but 2.1 doesn't
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
30 # support iterable access to file objects.
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
31 result = []
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
32 p = csv.parser(field_sep=dialect.delimiter)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
33
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
34 while 1:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
35 line = fileobj.readline()
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
36 if not line: break
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
37
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
38 # parse lines until we get a complete entry
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
39 while 1:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
40 fields = p.parse(line)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
41 if fields: break
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
42 line = fileobj.readline()
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
43 if not line:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
44 raise ValueError, "Unexpected EOF during CSV parse"
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
45 result.append(fields)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
46 return result
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
47 class writer:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
48 def __init__(self, fileobj, dialect=excel):
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
49 self.fileobj = fileobj
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
50 self.p = csv.parser(field_sep = dialect.delimiter)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
51 def writerow(self, fields):
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
52 print >>self.fileobj, self.p.join(fields)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
53 def writerows(self, rows):
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
54 for fields in rows:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
55 print >>self.fileobj, self.p.join(fields)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
56
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
57 except ImportError:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
58 class excel:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
59 pass
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
60
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
61 class colon_separated(excel):
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
62 delimiter = ':'
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
63 class comma_separated(excel):
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
64 delimiter = ','
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
65
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
66
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
67 if __name__ == "__main__":
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
68 f=open('testme.txt', 'r')
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
69 r = reader(f, colon_separated)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
70 remember = []
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
71 for record in r:
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
72 print record
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
73 remember.append(record)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
74 f.close()
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
75 import sys
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
76 w = writer(sys.stdout, colon_separated)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
77 w.writerows(remember)
d85cb1ad9bc9 merge from HEAD
Richard Jones <richard@users.sourceforge.net>
parents:
diff changeset
78

Roundup Issue Tracker: http://roundup-tracker.org/