openerp用wizard导入excel数据

作为一个quick note吧。
OE里的csv导入数据功能形同摆设,通俗地说就是弱爆了。
今天尝试一下用excel文件来导入数据。

在python里读取excel格式的lib很多,这里我选用的是xlrd。

上代码先:

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

from osv import osv, fields
import time, xlrd, base64


class bank_bill_import(osv.osv_memory):
    
    _name = "fg_account.bank_bill.import.wizard"
    _description = "导入账单"
    
    _columns = {
        'excel': fields.binary('excel文件', filters='*.xls'),
    }
    
    def import_bill(self, cr, uid, ids, context=None):
        for wiz in self.browse(cr,uid,ids):
            if not wiz.excel: continue
            
            excel = xlrd.open_workbook(file_contents=base64.decodestring(wiz.excel))
            sh = excel.sheet_by_index(0)
            print sh.name, sh.nrows, sh.ncols
            for rx in range(sh.nrows):
                for ry in range(sh.ncols):
                    print sh.cell(rx, ry).value
                    #这里做爱做的事情
            
        return {'type': 'ir.actions.act_window_close'}

其实重点就在于:

excel = xlrd.open_workbook(file_contents=base64.decodestring(wiz.excel))


你可能感兴趣的:(python,openerp)