のようにそれを解析することができ、文字列でDBからのコンテンツではなく、いくつかのDIYその場しのぎのものであり:
>>> import csv
>>> from cStringIO import StringIO
>>> fromDB = '"Column\nheading1",hdng2\r\n"data1\rfoo","data2\r\nfoo"\r\n'
>>> sources = [StringIO(fromDB), fromDB.splitlines(True),
... fromDB.splitlines(), fromDB.split("\n")]
>>> for i, source in enumerate(sources):
... print i, list(csv.reader(source))
...
0 [['Column\nheading1', 'hdng2'], ['data1\rfoo', 'data2\r\nfoo']] # OK
1 [['Column\nheading1', 'hdng2'], ['data1\rfoo', 'data2\r\nfoo']] # OK
2 [['Columnheading1', 'hdng2'], ['data1foo', 'data2foo']] # 3 errors
3 [['Columnheading1', 'hdng2'], ['data1\rfoo', 'data2\rfoo'], []] # 3 errors
>>>
guff.splitlines(True)
を使用していますあなたのコードを読んでいる人は、それが何をしているのかという手がかりを持たないだろうという理由で、それはStringIO(guff)
よりはるかに大きなチャンスを持っているのでお勧めできません。
"私は自分のデータベースにCSVデータを保存していますので、解析したいと思います。"これはあいまいです。 CSVファイル全体をグロブまたは文字列としてデータベースに保存していますか?すべての情報をデータベースのテーブルに格納していることを意味しますか?各列はCSVフィールドに対応します。 – gotgenes
ファイル全体をBLOBとして保存しています。 –
BLOBの構造は何ですか?代わりにデータをピクルするオプションがありますか? – jbcurtin