def pesquisar_transportador(sap_session, criterio): try: SAPTransaction.call(sap_session, 'xk03') if len(criterio) != 7: criterio = XK03.__pesquisar_codigo_transportador_por_cnpj_ou_cpf( sap_session, criterio) XK03.__abrir_transacao(sap_session, criterio) nome = SAPGuiElements.get_text(sap_session, ELEMENTO_NOME) SAPGuiElements.press_button(sap_session, ELEMENTO_PROXIMA_PAGINA) identificador = SAPGuiElements.get_text(sap_session, ELEMENTO_CNPJ) if not identificador: identificador = SAPGuiElements.get_text( sap_session, ELEMENTO_CPF) codigo_municipio = SAPGuiElements.get_text( sap_session, ELEMENTO_CODIGO_MUNICIPIO) codigo_municipio = "".join(re.findall("\\d*", codigo_municipio)) municipio = MunicipioService.pesquisar_municipio_pelo_codigo( codigo_municipio) if municipio is None: raise RuntimeError( 'Não possivel definir o municipio do transportador!') transportador = Transportador() transportador.nome = nome transportador.codigo_sap = criterio transportador.cnpj_cpf = identificador transportador.municipio = municipio transportador.save() return transportador except Exception as e: traceback.print_exc(file=sys.stdout) raise e
def criar_remessa(sap_session, remessa, remessa_sem_transporte=False): try: ordem = remessa.itens[0].numero_ordem SAPTransaction.call(sap_session, 'vl01n') SAPGuiElements.set_text(sap_session, SHIPPING_PLACE_FIELD, SHIPPING_PLACE_VALUE) SAPGuiElements.set_text(sap_session, SHIPPING_ORDER_FIELD, ordem) SAPGuiElements.press_keyboard_keys(sap_session, "Enter") # verificando se houve alguma mensagem de erro. # Uma exceçao será lançada no caso de erro. SAPGuiElements.verificar_mensagem_barra_inferior(sap_session) SAPGuiElements.select_element(sap_session, ELEMENTO_ABA_PICKING) linha = 0 for item in remessa.itens: item_str = VL01.__procurar_item_pelo_codigo_produto( sap_session, item.produto.codigo_sap, ordem) VL01.__inserir_deposito(sap_session, item.produto.deposito, item_str) VL01.__inserir_lote(sap_session, item.produto.lote, item_str) VL01.__inserir_quantidade(sap_session, item.quantidade, item_str) VL01.__inserir_picking(sap_session, item.quantidade, item_str) VL01.__alterar_direitos_fiscais_se_necessario( sap_session, item.produto, linha) VL01.__inserir_dados_cabecalho(sap_session, remessa.itens[0].produto) SAPGuiElements.enter(sap_session) # ignorando alerta de remessas parciais SAPGuiElements.ignorar_alerta(sap_session) if SAPGuiElements.verificar_mensagem_barra_inferior(sap_session): SAPGuiElements.enter(sap_session) SAPGuiElements.salvar(sap_session) # ignorando alerta de remessas parciais SAPGuiElements.ignorar_alerta(sap_session) # verificando se houve alguma mensagem de erro. mensagem = SAPGuiElements.verificar_mensagem_barra_inferior( sap_session) # retornando o número da remessa return VL01.extrair_numero_remessa(mensagem) except Exception as e: raise e
def inserir_inspecao_veicular(sap_session, numero_transporte, numero_inspecao_veicular): SAPTransaction.call(sap_session, 'vt02n') SAPGuiElements.set_text(sap_session, ELEMENTO_NUMERO_TRANSPORTE, numero_transporte) SAPGuiElements.press_keyboard_keys(sap_session, "Enter") SAPGuiElements.select_element(sap_session, ELEMENTO_ABA_IDENTIFICACAO) SAPGuiElements.set_text(sap_session, ELEMENTO_NUMERO_INSPECAO_VEICULAR, numero_inspecao_veicular) SAPGuiElements.press_button(sap_session, SAVE_BUTTON) tipo_mensagem = SAPGuiElements.get_sbar_message_type(sap_session) if tipo_mensagem and tipo_mensagem == 'S': return True, "" return False, "Erro ao inserir inspecao {} no transporte {}".format( numero_inspecao_veicular, numero_transporte)
def gerar_produto_remessa_pronta(sap_session, numero_remessa): try: SAPTransaction.call(sap_session, 'vl03n') SAPGuiElements.set_text(sap_session, ELEMENTO_CAMPO_REMESSA, numero_remessa) SAPGuiElements.press_keyboard_keys(sap_session, "Enter") SAPGuiElements.verificar_mensagem_barra_inferior(sap_session) remessa = Remessa(None, None) proximo_item = True c = 0 while proximo_item: numero_item = SAPGuiElements.get_text( sap_session, ELEMENTO_NUMERO_ITEM.format(str(c))) proximo_item = str(numero_item).isdigit() if proximo_item: codigo_produto = SAPGuiElements.get_text( sap_session, ELEMENTO_CODIGOS_PRODUTO.format(str(c))) deposito = SAPGuiElements.get_text( sap_session, ELEMENTO_DEPOSITOS.format(str(c))) quantidade = SAPGuiElements.get_text( sap_session, ELEMENTO_QUANTIDADES.format(str(c))) lote = SAPGuiElements.get_text( sap_session, ELEMENTO_LOTES.format(str(c))) produto = ProdutoService.pesquisar_produto_pelo_id( codigo_produto) ''' # TODO informar ao usuario se ele deseja continuar caso lote ou deposito esteja diferente if produto.lote != lote: raise RuntimeError('Lote da remessa diferente do lote cadastrado para o produto {}!' .format(produto.nome)) if produto.deposito != deposito: raise RuntimeError('Deposito da remessa diferente do deposito cadastrado para o produto {}!' .format(produto.nome)) ''' item = ItemRemessa(quantidade=quantidade, produto=produto, numero_item=numero_item) remessa.itens.append(item) c += 1 return remessa except Exception as e: print(e)
def __abrir_transacao(sap_session, numero_inspecao_veicular): SAPTransaction.call(sap_session, 'qe01') SAPGuiElements.set_text(sap_session, ELEMENTO_LOTE_CONTROLE, numero_inspecao_veicular) SAPGuiElements.set_text(sap_session, ELEMENTO_OPERACAO, "0010") SAPGuiElements.set_text(sap_session, ELEMENTO_CENTRO, "1014") sap_session.findById(ELEMENTO_FILTRO_CARACTERISTICAS).key = 1 SAPGuiElements.press_keyboard_keys(sap_session, "Enter") existe_proxima_operacao = True while existe_proxima_operacao: ''' row = 0 while row < sap_session.findById(ELEMENTO_TABELA_RESULTADOS).RowCount: # print(row) # print(SAPGuiElements.get_text(sap_session, ELEMENTO_COLUNA_S.format(row))) # session.findById(ELEMENTO_TABELA_RESULTADOS).selectedRows = row row += 1 ''' QE01.__inserir_s(sap_session) SAPGuiElements.press_button(sap_session, ELEMENTO_BOTAO_SELECIONAR_TODOS) SAPGuiElements.press_button(sap_session, ELEMENTO_BOTAO_AVALIAR) # TODO verificar essa lógica SAPGuiElements.press_button(sap_session, ELEMENTO_BOTAO_PROXIMA_OPERACAO) existe_proxima_operacao = SAPGuiElements.is_enable( sap_session, ELEMENTO_BOTAO_PROXIMA_OPERACAO) try: SAPGuiElements.press_button(sap_session, ELEMENTO_BOTAO_GRAVAR_PRIMEIRO) except AttributeError: pass SAPGuiElements.press_button(sap_session, SAVE_BUTTON) tipo_mensagem = SAPGuiElements.get_sbar_message_type(sap_session) message = SAPGuiElements.get_text(sap_session, MESSAGE_ELEMENT) if tipo_mensagem and tipo_mensagem == 'S': return True, message else: return False, message
def create(sap_session, lote_inspecao): try: SAPTransaction.call(sap_session, 'qa01') SAPGuiElements.set_text(sap_session, ELEMENTO_CODIGO_PRODUTO, lote_inspecao.material) SAPGuiElements.set_text(sap_session, ELEMENTO_CENTRO, CENTRO) SAPGuiElements.set_text(sap_session, ELEMENTO_LOTE_ORIGEM, lote_inspecao.origem) SAPGuiElements.press_keyboard_keys(sap_session, "Enter") # verificando se o lote é de inspecao de produto(89) ou de veiculo(07) inspecionando_produto = lote_inspecao.origem == "89" if inspecionando_produto: sap_session.findById("wnd[1]/usr/lbl[1,3]").setFocus() SAPGuiElements.press_keyboard_keys(sap_session, "Enter") SAPGuiElements.set_text(sap_session, ELEMENTO_QUANTIDADE_LOTE, QUANTIDADE_LOTES) SAPGuiElements.set_text(sap_session, ELEMENTO_TXT_BREVE_INSP_PRODUTO, lote_inspecao.texto_breve) else: SAPGuiElements.set_text(sap_session, ELEMENTO_TXT_BREVE_INSP_VEICULO, lote_inspecao.texto_breve) # o lote e o deposito sao setados agora pq caso o lote seja de inspecao de produto, o sap mostra uma # mensagem antes de abrir a tela do lote SAPGuiElements.set_text(sap_session, ELEMENTO_LOTE, lote_inspecao.lote) SAPGuiElements.set_text(sap_session, ELEMENTO_DEPOSITO, lote_inspecao.deposito if lote_inspecao.deposito is not None else '') SAPGuiElements.salvar(sap_session) try: SAPGuiElements.press_button(sap_session, OPTIONAL_CREATE) error_message = SAPGuiElements.get_text(sap_session, ERROR_MESSAGE_ELEMENT) if error_message: raise RuntimeError(QA01.get_formated_error_message(error_message, lote_inspecao.texto_breve)) except AttributeError: pass mensagem = SAPGuiElements.verificar_mensagem_barra_inferior(sap_session) return QA01.get_batch_controller_number(mensagem) except Exception as e: traceback.print_exc(file=sys.stdout) raise e
def __abrir_transacao(sap_session): SAPTransaction.call(sap_session, 'vt01n') SAPGuiElements.set_text(sap_session, ELEMENTO_ORGANIZACAO, "1000") sap_session.findById(ELEMENTO_TIPO_TRANSPORTE).key = "ZDIR" SAPGuiElements.press_keyboard_keys(sap_session, "Enter")
def consultar_saldo_cliente(sap_session, cnpj, data_inicial, data_final, produto): SAPTransaction.call(sap_session, 'zsd020') SAPGuiElements.set_text(sap_session, ELEMENTO_LOCAL_NEGOCIOS, '1014') SAPGuiElements.set_text(sap_session, ELEMENTO_ORGANIZACAO_VENDAS, '1000') SAPGuiElements.set_text(sap_session, ELEMENTO_CANAL_DISTRIBUICAO, produto.canal_distribuicao.codigo) SAPGuiElements.set_text(sap_session, ELEMENTO_SETOR_VENDAS, produto.setor_atividade.codigo) SAPGuiElements.set_text(sap_session, ELEMENTO_DATA_INICIAL, data_inicial) SAPGuiElements.set_text(sap_session, ELEMENTO_DATA_FINAL, data_final) SAPGuiElements.set_text(sap_session, ELEMENTO_CODIGO_MATERIAL, produto.codigo_sap) SAPGuiElements.select_element(sap_session, ELEMENTO_APENAS_ORDENS_VENDA) SAPGuiElements.set_checkbox(sap_session, ELEMENTO_INCLUIR_BLOQUEADAS) SAPGuiElements.set_focus(sap_session, ELEMENTO_EMISSOR_ORDEM) SAPGuiElements.send_key(sap_session, 4) SAPGuiElements.set_text(sap_session, ELEMENTO_CAMPO_CNPJ, cnpj) SAPGuiElements.enter(sap_session) SAPGuiElements.enter(sap_session) SAPGuiElements.send_key(sap_session, 8) if SAPGuiElements.verificar_mensagem_barra_inferior(sap_session): return [] SAPGuiElements.press_button(sap_session, ELEMENTO_BOTAO_SELECIONAR_LAYOUT) row = 0 while row < sap_session.findById(ELEMENTO_TABELA_LAYOUTS).RowCount: nome_layout = sap_session.findById(ELEMENTO_TABELA_LAYOUTS).GetCellValue(row, "TEXT") if nome_layout == 'KSLIMA': sap_session.findById(ELEMENTO_TABELA_LAYOUTS).selectedRows = row sap_session.findById(ELEMENTO_TABELA_LAYOUTS).setCurrentCell(row, "TEXT") sap_session.findById(ELEMENTO_TABELA_LAYOUTS).firstVisibleRow = row sap_session.findById(ELEMENTO_TABELA_LAYOUTS).clickCurrentCell() break row += 1 row = 0 ordens = [] while row < sap_session.findById(ELEMENTO_TABELA_ORDENS).RowCount: # converterndo o número da ordem para inteiro e assim eliminar os zeros a esquerda numero_ordem = str(int(sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_ORDEM))) data = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_DATA) cidade = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_CIDADE) uf = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_UF) cliente = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_CLIENTE) qtd = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_QTD_ORDEM) qtd_saida = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_QTD_SAIDA) qtd_disponivel = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_QTD_DISPONIVEL) material = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_MATERIAL) codigo_material = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_COD_MATERIAL) codigo_material = str(int(codigo_material)) pedido = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_PEDIDO) tipo_ordem = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_TIPO_ORDEM) status = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_STATUS) cnpj = sap_session.findById(ELEMENTO_TABELA_ORDENS).GetCellValue(row, ELEMENTO_COLUNA_CNPJ) ordem = Ordem() ordem.data = data ordem.numero = numero_ordem ordem.material = material ordem.codigo_material = codigo_material ordem.cliente = cliente ordem.cidade = cidade ordem.uf = uf ordem.qtd = qtd ordem.qtd_saida = qtd_saida ordem.qtd_disponivel = qtd_disponivel ordem.pedido = pedido ordem.tipo = tipo_ordem ordem.cnpj = cnpj ordem.status = status ordens.append(ordem) row += 1 return ordens