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