OpenERP 7:如何将解码文件作为CSV文件打开?

时间:2015-05-12 17:39:46

标签: python csv decode openerp-7

我有一个模块,要求用户提供带有二进制字段的csv文件。所以一旦模块有了它,我解码它并将结果写入临时文件,但是我不能将其作为CSV文件打开:我将得到错误" TypeError:强制转换为Unicode:需要字符串或缓冲区,找到的文件"因为我试图打开一个文件对象。那么如何解码文件然后将其作为CSV文件打开?

这是我的代码:

# -*- coding: utf-8 -*-

from osv import fields, osv
import csv
import base64
from tempfile import TemporaryFile

class set_dates(osv.osv_memory):
    _name = "set.dates"

    _columns = {
        "donnees": fields.binary("Données", required=True)
    }

    def do_set(self, cr, uid, ids, data, context=None):

        this = self.browse(cr, uid, ids[0])
        fileobj = TemporaryFile('w+')
        fileobj.write(base64.decodestring(this.donnees))

        fic = csv.reader(open(fileobj, "rb"))
        tab = list(fic)
        #...

提前感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

错误在fic = csv.reader(open(fileobj, "rb"))

open()抱怨它的参数是一个文件对象,而不是字符串或缓冲区。那是因为变量fileobj是一个file对象,它以:

打开

fileobj = TemporaryFile('w+')

你只需要替换:
fic = csv.reader(open(fileobj, "rb"))
搭配:
fic = csv.reader(fileobj)