コード例 #1
0
ファイル: invoices.py プロジェクト: rodrigosuhr/KarateManager
def get_invoice(bill_to, amount, due_date):
    d = BoletoBB(7, 2)
    d.nosso_numero = '0000000127'
    d.numero_documento = ''
    d.convenio = '2301731'
    d.especie_documento = 'DM'

    d.carteira = '18'
    d.cedente = 'Confederação Brasileira de Karatê-Dô Tradicional'
    d.cedente_documento = "35.795.707/0001-16"
    d.cedente_endereco = "Rua Acme, 123 - Centro - Sao Paulo/SP - CEP: 12345-678"
    d.agencia_cedente = '1458'
    d.conta_cedente = '189448'

    d.data_vencimento = datetime.date(2011, 10, 25)
    d.data_documento = datetime.date(2010, 2, 12)
    d.data_processamento = datetime.date(2010, 2, 12)

    d.instrucoes = [
        "- NÃO RECEBER APÓS 5 DIAS DE VENCIDO",
        "- APÓS O VENCIMENTO COBRAR 0,03% POR DIA DE ATRASO",
        "- APÓS O VENCIMENTO COBRAR MULTA DE 2%",
        ]
    d.demonstrativo = [
        "- Anuidades",
        ]
    d.valor_documento = 120.00

    d.sacado = [
        "Cliente Teste",
        ""
        ]
    return d
コード例 #2
0
ファイル: pyboleto_sample.py プロジェクト: ricoboni/pyboleto
def get_data_bb():
    listaDados = []
    for i in range(2):
        d = BoletoBB(7, 2)
        d.nosso_numero = "87654"
        d.numero_documento = "27.030195.10"
        d.convenio = "7777777"
        d.especie_documento = "DM"

        d.carteira = "18"
        d.cedente = "Empresa ACME LTDA"
        d.cedente_documento = "102.323.777-01"
        d.cedente_endereco = "Rua Acme, 123 - Centro - Sao Paulo/SP - CEP: 12345-678"
        d.agencia_cedente = "9999"
        d.conta_cedente = "99999"

        d.data_vencimento = datetime.date(2010, 3, 27)
        d.data_documento = datetime.date(2010, 2, 12)
        d.data_processamento = datetime.date(2010, 2, 12)

        d.instrucoes = [
            "- Linha 1",
            "- Sr Caixa, cobrar multa de 2% após o vencimento",
            "- Receber até 10 dias após o vencimento",
        ]
        d.demonstrativo = ["- Serviço Teste R$ 5,00", "- Total R$ 5,00"]
        d.valor_documento = 255.00

        d.sacado = ["Cliente Teste %d" % (i + 1), "Rua Desconhecida, 00/0000 - Não Sei - Cidade - Cep. 00000-000", ""]
        listaDados.append(d)
    return listaDados
コード例 #3
0
ファイル: factories.py プロジェクト: Bindambc/segue
    def create(self, payment):
        boleto = BoletoBB(config.BOLETO_TIPO_CONVENIO, None)

        boleto.nosso_numero      = payment.our_number
        boleto.convenio          = config.BOLETO_CONVENIO
        boleto.numero_documento  = "{}{}".format(boleto.convenio, boleto.nosso_numero)
        boleto.especie_documento = 'DM'

        boleto.carteira          = config.BOLETO_CARTEIRA
        boleto.agencia_cedente   = config.BOLETO_AGENCIA
        boleto.conta_cedente     = config.BOLETO_CONTA # TODO: what about digito-verificador?
        boleto.cedente_documento = config.BOLETO_CNPJ
        boleto.cedente_endereco  = config.BOLETO_ENDERECO
        boleto.cedente           = config.BOLETO_EMPRESA

        boleto.data_vencimento    = payment.due_date
        boleto.data_documento     = date.today()
        boleto.data_processamento = date.today()

        boleto.instrucoes    = self._build_instructions()
        boleto.demonstrativo = self._build_description(payment)
        boleto.sacado        = self._build_sacado(payment)

        boleto.valor_documento = payment.amount
        return boleto
コード例 #4
0
ファイル: util.py プロジェクト: sidneysm/CursoOpcao
def print_bb(Aluno):
    """
    Recebe uma instância de Aluno e gera boletos com as insformações passadas
    """
    listaDados = []
    for i in range(1):
        d = BoletoBB(7, 2)

        d.nosso_numero = "%d" % (i + 1)
        d.numero_documento = "123456789"
        d.convenio = "7777777"
        d.especie_documento = "DM"

        d.carteira = "18"
        d.cedente = "Curso Opção Triunfo"
        d.cedente_documento = "05261501490"
        d.cedente_endereco = "Rua Alameda das Mansões"
        d.agencia_cedente = "2739"
        d.conta_cedente = "12097"

        d.data_vencimento = datetime.date(2015, 12, 21)
        d.data_documento = datetime.date(2015, 12, 20)
        d.data_processamento = datetime.date(2015, 12, 20)

        d.instrucoes = ["- Sr Caixa, cobrar multa de 2% após vencimento", "- Receber até 10 dias após vencimento"]
        d.demonstrativo = ["- Testando pagamento", "- Total R$ 5,00"]
        d.valor_documento = Decimal(600)

        d.sacado_nome = Aluno.first_name
        d.sacado_documento = Aluno.cpf
        d.sacado_cidade = Aluno.endereco
        d.sacado_uf = "RN"
        d.sacado_endereco = "Rua rua"
        d.sacado_bairro = "Sao Pedro"
        d.sacado_cep = "3333333"

        d.valor = Decimal(600)
        d.valor_documento = Decimal(600)

        d.quantidade = "1"

        d.barcode

        listaDados.append(d)

        boleto = BoletoPDF("curso/boletos/boleto-teste-%s.pdf" % d.sacado_nome)

        for i in listaDados:
            boleto.drawBoleto(i)
            boleto.nextPage()
            boleto.save()
コード例 #5
0
ファイル: view_boleto.py プロジェクト: swgt/educarinova
def print_bb():
    listaDados = []
    for i in range(2):
        d = BoletoBB(7, 2)
        d.nosso_numero = '87654'
        d.numero_documento = '27.030195.10'
        d.convenio = '7777777'
        d.especie_documento = 'DM'

        d.carteira = '18'
        d.cedente = 'Educarinova'
        d.cedente_documento = "102.323.777-01"
        d.cedente_endereco = ("Rua Acme, 123 - " +
                              "Centro - Sao Paulo/SP - " +
                              "CEP: 12345-678")
        d.agencia_cedente = '9999111'
        d.conta_cedente = '999991111'

        d.data_vencimento = datetime.date(2010, 3, 27)
        d.data_documento = datetime.date(2010, 2, 12)
        d.data_processamento = datetime.date(2010, 2, 12)

        d.instrucoes = [
            "- Linha 1",
            "- Sr Caixa, cobrar multa de 2% após o vencimento",
            "- Receber até 10 dias após o vencimento",
            ]
        d.demonstrativo = [
            "- Serviço Teste R$ 5,00",
            "- Total R$ 5,00",
            ]
        d.valor_documento = 255.00

        d.sacado = [
            "Cliente Teste %d" % (i + 1),
            "Rua Desconhecidaasdasd, 00/0000 - Não Sei - Cidade - Cep. 00000-000",
            ""
            ]
        listaDados.append(d)

    boleto = BoletoPDF('boleto-bb-formato-normal-teste.pdf')
    for i in range(len(listaDados)):
        boleto.drawBoleto(listaDados[i])
        boleto.nextPage()
    boleto.save()
コード例 #6
0
def print_bb(prazo, valor, nomeCliente):
    listaDados = []
    for i in range(1):
        d = BoletoBB(7, 2)
        d.nosso_numero = '87654'
        d.numero_documento = '27.030195.10'
        d.convenio = '7777777'
        d.especie_documento = 'DM'

        d.carteira = '18'
        d.cedente = 'AS PARTNERS LTDA'
        d.cedente_documento = "102.323.777-01"
        d.cedente_endereco = ("Avenida Cassiano Ricardo, 319," +
                              "Sala 508-5ºAndar-" + "Jd.Aquarius-SJC/SP")
        d.agencia_cedente = '9999'
        d.conta_cedente = '99999'

        #today = date.today() + timedelta(prazo)
        d.data_vencimento = datetime.date(2018, 8, 29)
        d.data_documento = datetime.date(2010, 2, 12)
        d.data_processamento = datetime.date(2010, 2, 12)

        d.instrucoes = [
            "- Linha 1",
            "- Sr Caixa, cobrar multa de 2% após o vencimento",
            "- Receber até 10 dias após o vencimento",
        ]
        d.demonstrativo = [
            "- Serviço Teste R$ 5,00",
            "- Total R$ 5,00",
        ]
        d.valor_documento = valor

        d.sacado = [
            nomeCliente,
            "Rua Desconhecida, 00/0000 - Não Sei - Cidade - Cep. 00000-000", ""
        ]
        listaDados.append(d)

    boleto = BoletoPDF('boleto-bb-formato-normal-teste.pdf')
    for i in range(len(listaDados)):
        boleto.drawBoleto(listaDados[i])
        boleto.nextPage()
    boleto.save()
コード例 #7
0
def print_bb():
    listaDados = []
    for i in range(2):
        d = BoletoBB(7, 2)
        d.nosso_numero = '87654'
        d.numero_documento = '27.030195.10'
        d.convenio = '7777777'
        d.especie_documento = 'DM'

        d.carteira = '18'
        d.cedente = 'Empresa ACME LTDA'
        d.cedente_documento = "102.323.777-01"
        d.cedente_endereco = ("Rua Acme, 123 - " + "Centro - Sao Paulo/SP - " +
                              "CEP: 12345-678")
        d.agencia_cedente = '9999'
        d.conta_cedente = '99999'

        d.data_vencimento = datetime.date(2010, 3, 27)
        d.data_documento = datetime.date(2010, 2, 12)
        d.data_processamento = datetime.date(2010, 2, 12)

        d.instrucoes = [
            "- Linha 1",
            "- Sr Caixa, cobrar multa de 2% após o vencimento",
            "- Receber até 10 dias após o vencimento",
        ]
        d.demonstrativo = [
            "- Serviço Teste R$ 5,00",
            "- Total R$ 5,00",
        ]
        d.valor_documento = 255.00

        d.sacado = [
            "Cliente Teste %d" % (i + 1),
            "Rua Desconhecida, 00/0000 - Não Sei - Cidade - Cep. 00000-000", ""
        ]
        listaDados.append(d)

    boleto = BoletoPDF('boleto-bb-formato-normal-teste.pdf')
    for i in range(len(listaDados)):
        boleto.drawBoleto(listaDados[i])
        boleto.nextPage()
    boleto.save()
コード例 #8
0
def get_data_bb():
    listaDados = []
    for i in range(2):
        d = BoletoBB(7, 2)
        d.nosso_numero = "87654"
        d.numero_documento = "27.030195.10"
        d.convenio = "7777777"
        d.especie_documento = "DM"

        d.carteira = "18"
        d.cedente = "Empresa ACME LTDA"
        d.cedente_documento = "102.323.777-01"
        d.cedente_endereco = "Rua Acme, 123 - Centro - Sao Paulo/SP - CEP: 12345-678"
        d.agencia_cedente = "9999"
        d.conta_cedente = "99999"

        d.data_vencimento = datetime.date(2010, 3, 27)
        d.data_documento = datetime.date(2010, 2, 12)
        d.data_processamento = datetime.date(2010, 2, 12)

        d.instrucoes = [
            "- Linha 1",
            "- Sr Caixa, cobrar multa de 2% após o vencimento",
            "- Receber até 10 dias após o vencimento",
        ]
        d.demonstrativo = [
            "- Serviço Teste R$ 5,00",
            "- Total R$ 5,00",
        ]
        d.valor_documento = 255.00

        d.sacado = [
            "Cliente Teste %d" % (i + 1),
            "Rua Desconhecida, 00/0000 - Não Sei - Cidade - Cep. 00000-000",
            "",
        ]
        listaDados.append(d)
    return listaDados
コード例 #9
0
    def gen_boleto(self, cr, uid, ids, boleto_id, context=None):
        uid = 1
        boleto_boleto = self.pool.get('boleto.boleto')
        account_analytic_account = self.pool.get('account.analytic.account')
        account_analytic_charges_line = self.pool.get(
            'account.analytic.charges.line')
        res_company = self.pool.get('res.company').browse(cr, uid, 1)
        #  res_currency                  = self.pool.get('res.currency').browse(cr, uid, res_company.currency_id.id)

        partner_obj = self.pool.get('')
        fbuffer = StringIO()
        boleto_pdf = BoletoPDF(fbuffer)
        lista_produtos = context['lista']
        multa = 0
        mora = 0
        bol = boleto_boleto.browse(cr, uid, boleto_id, context=context)

        if bol.banco == 'bb':
            boleto = BoletoBB(7, 2)
        elif bol.banco == 'bradesco':
            boleto = BoletoBradesco()
        elif bol.banco == 'caixa':
            boleto = BoletoCaixa()
        elif bol.banco == 'real':
            boleto = BoletoReal()
        elif bol.banco == 'itau':
            boleto = BoletoItau()

        boleto.demonstrativo = []

        end_company = "%s, %s  %s  %s" % (
            bol.cedente.partner_id.street or '', bol.cedente.partner_id.number
            or '', bol.cedente.partner_id.district
            or '', bol.cedente.partner_id.city or '')
        boleto.cedente_documento = bol.cedente.partner_id.cnpj_cpf
        boleto.cedente = "%s   CNPJ: %s" % (bol.cedente.name,
                                            bol.cedente.partner_id.cnpj_cpf)
        boleto.carteira = bol.carteira
        if bol.banco == 'caixa':
            boleto.carteira = 'SR'
        else:
            boleto.carteira = bol.carteira
        boleto.agencia_cedente = bol.agencia_cedente
        boleto.conta_cedente = bol.conta_cedente
        boleto.data_vencimento = datetime.date(
            datetime.strptime(bol.data_vencimento, '%Y-%m-%d'))
        boleto.data_documento = date.today(
        )  #datetime.date(datetime.strptime(bol.data_documento, '%Y-%m-%d'))
        boleto.data_processamento = date.today()
        boleto.nosso_numero = bol.nosso_numero
        if bol.banco == 'caixa':
            n = list(boleto.nosso_numero)
            n[0] = '2'
            n[1] = '4'
            n[2] = '2'
            boleto.nosso_numero = "".join(n)
            boleto.especie_documento = 'DS'
        boleto.numero_documento = bol.numero_documento
        boleto.convenio = bol.convenio
        pp = self.pool.get('boleto.partner_config').search(
            cr, uid, [('default_boleto', '=', True)])
        if bol.instrucoes:
            instrucoes = bol.instrucoes
        elif pp:
            ppb = self.pool.get('boleto.partner_config').browse(cr, uid, pp[0])
            instrucoes = ppb.instrucoes
        else:
            raise osv.except_osv((u'Atencao !'), (
                "Para gerar boletos primeiro cadastre a configuracao de boleto deste cliente."
            ))
        boleto.instrucoes = []

        contrato_id = account_analytic_account.search(
            cr, uid, [('code', '=', str(context['contrato']))])

        #         lista_encargos = account_analytic_charges_line.search(cr, uid, [('analytic_account_id', '=', contrato_id)])
        #
        #         for charge in account_analytic_charges_line.browse(cr, uid, lista_encargos):
        #             if charge.type_charge == 'mora':
        #                 mora = charge.perc_charge
        #             elif charge.type_charge == 'multa':
        #                 multa = charge.perc_charge
        #
        boleto.valor_documento = bol.valor
        multa_ok = 0
        mora_ok = 0
        #         for k in bol.instrucoes.split('\n'):
        h = normalize('NFKD', unicode(instrucoes)).encode('ASCII', 'ignore')
        #         if multa and multa_ok == 0:
        #             #multa = "%s%s" % (multa, '%')
        #             multa = multa / 100
        #             multa = str("%.2f" % (float(multa) * float(boleto.valor_documento))).replace('.',',')
        #             multa = "%s%s" % ("R$", multa)
        #             h = h.replace('@multa', multa)
        #             multa_ok = 1
        #         if mora and mora_ok == 0:
        #             #mora = "%s%s" % (mora, '%')
        #             mora = mora / 100
        #             mora = str("%.2f" % (float(mora) * float(boleto.valor_documento))).replace('.',',')
        #             mora = "%s%s" % ("R$", mora)
        #             h = h.replace('@mora', mora)
        #             mora_ok = 1
        for k in h.split('\n'):
            boleto.instrucoes.append(k)

        boleto.cedente_endereco = normalize('NFKD',
                                            unicode(end_company or '')).encode(
                                                'ASCII', 'ignore')
        sac = normalize(
            'NFKD',
            unicode("%s           CNPJ/CPF:%s" %
                    (bol.sacado.legal_name or bol.sacado.name,
                     bol.sacado.cnpj_cpf))).encode('ASCII', 'ignore')
        end = normalize(
            'NFKD',
            unicode(
                "%s, %s  %s  %s" %
                (bol.sacado.street or '', bol.sacado.number or '',
                 bol.sacado.street2 or '', bol.sacado.district or ''))).encode(
                     'ASCII', 'ignore')
        boleto.sacado = [
            (normalize(
                'NFKD',
                unicode('%s  CNPJ/CPF: %s' %
                        (bol.sacado.name or bol.sacado.legal_name or '',
                         str(bol.sacado.cnpj_cpf)))).encode('ASCII',
                                                            'ignore')), end,
            ("%s            CEP: %s" % (bol.sacado.city, bol.sacado.zip))
        ]
        boleto.demonstrativo = [
            str(sac[:90]),
            "%s" % (bol.name),
            str(end[:90]),
            "%s            CEP: %s" % (bol.sacado.city, bol.sacado.zip),
            "__________________________________________________________________________________________",
            "REFERENTE A SERVIÇOS",
            "Produto".ljust(35) + "Valor".rjust(15),
            "",
        ]
        for i in lista_produtos:
            i = normalize('NFKD', unicode(i[:90])).encode('ASCII', 'ignore'),
            boleto.demonstrativo.append(str(unicode(i[0])))

        print boleto
        boleto_pdf.drawBoleto(boleto)
        print boleto.linha_digitavel
        boleto_pdf.save()

        boleto_file = fbuffer.getvalue().encode("base64")
        fbuffer.close()
        return boleto_file
コード例 #10
0
    def gen_boleto(self, cr, uid, ids, boleto_id, context=None):
        uid = 1
        boleto_boleto                 = self.pool.get('boleto.boleto')
        fbuffer     = StringIO()
        boleto_pdf  = BoletoPDF(fbuffer)
        lista_produtos = context['lista']
        bol = boleto_boleto.browse(cr, uid, boleto_id, context=context)

        if bol.banco == 'bb':
            boleto = BoletoBB(7, 2)
        elif bol.banco == 'bradesco':
            boleto = BoletoBradesco()
        elif bol.banco == 'caixa':
            boleto = BoletoCaixa()
        elif bol.banco == 'real':
            boleto = BoletoReal()
        elif bol.banco == 'itau':
            boleto = BoletoItau()
            
        boleto.demonstrativo = []
        
        end_company = "%s, %s  %s  %s" % (bol.cedente.partner_id.street or '', 
                                          bol.cedente.partner_id.number or '', 
                                          bol.cedente.partner_id.district or '', 
                                          bol.cedente.partner_id.city or '')
        boleto.cedente_documento = bol.cedente.partner_id.cnpj_cpf
        boleto.cedente  = "%s   CNPJ: %s" % (bol.cedente.name,bol.cedente.partner_id.cnpj_cpf)
        boleto.carteira = bol.carteira
        if bol.banco == 'caixa':
            boleto.carteira = 'SR'
        else:
            boleto.carteira = bol.carteira
        boleto.agencia_cedente  = bol.agencia_cedente
        boleto.conta_cedente    = bol.conta_cedente    
        boleto.data_vencimento  = datetime.date(datetime.strptime(bol.data_vencimento, '%Y-%m-%d'))
        boleto.data_documento   = date.today()#datetime.date(datetime.strptime(bol.data_documento, '%Y-%m-%d'))
        boleto.data_processamento = date.today()
        boleto.nosso_numero     = bol.nosso_numero
        if bol.banco == 'caixa':
            n = list(boleto.nosso_numero)
            n[0] = '2'
            n[1] = '4'
            n[2] = '2'
            boleto.nosso_numero = "".join(n)
            boleto.especie_documento = 'DS'
        boleto.numero_documento = bol.numero_documento
        boleto.convenio         = bol.convenio
        pp = self.pool.get('boleto.partner_config').search(cr, uid, [('default_boleto','=',True)])
        if bol.instrucoes:
            instrucoes = bol.instrucoes
        elif pp:
            ppb = self.pool.get('boleto.partner_config').browse(cr, uid, pp[0])
            instrucoes = ppb.instrucoes
        else:
            raise osv.except_osv((u'Atencao !'),("Para gerar boletos primeiro cadastre a configuracao de boleto deste cliente."))
        boleto.instrucoes = []
        
        boleto.valor_documento  = bol.valor
        h = normalize('NFKD',unicode(instrucoes)).encode('ASCII','ignore')
        for k in h.split('\n'):
            boleto.instrucoes.append(k)
            
        boleto.cedente_endereco = normalize('NFKD',unicode(end_company or '')).encode('ASCII','ignore')
        sac = normalize('NFKD',unicode("%s           CNPJ/CPF:%s" 
            % (bol.sacado.legal_name or bol.sacado.name,bol.sacado.cnpj_cpf))).encode('ASCII','ignore')
        end = normalize('NFKD',unicode("%s, %s  %s  %s" 
            % (bol.sacado.street or '', bol.sacado.number or '', bol.sacado.street2 or '', bol.sacado.district or ''))).encode('ASCII','ignore')
        boleto.sacado = [(normalize('NFKD',unicode('%s  CNPJ/CPF: %s' 
                        % (bol.sacado.name or bol.sacado.legal_name or '',
                           str(bol.sacado.cnpj_cpf)))).encode('ASCII','ignore')), end,
                         ("%s            CEP: %s" % (bol.sacado.city,bol.sacado.zip))]
        boleto.demonstrativo =[
            str(sac[:90]),
            "%s" % (bol.name),
            str(end[:90]),
            "%s            CEP: %s" % (bol.sacado.city,bol.sacado.zip),
            "__________________________________________________________________________________________",              
            "REFERENTE A SERVIÇOS",
            "Produto".ljust(35)  + "Valor".rjust(15),
            "",
            ]
        for i in lista_produtos:
            i = normalize('NFKD',unicode(i[:90])).encode('ASCII','ignore'),
            boleto.demonstrativo.append(str(unicode(i[0]))) 
            
        print boleto
        boleto_pdf.drawBoleto(boleto)
        print boleto.linha_digitavel
        boleto_pdf.save()
            
        boleto_file = fbuffer.getvalue().encode("base64")
        fbuffer.close()
        return boleto_file