def save_config(self, fn_channel = DIR_DEFAULT_CONF_CHANNEL, fn_pocket = DIR_DEFAULT_CONF_POCKET): """ Save configs: reverse of load_config Configs can be modified during execution. snsapi components communicate with upper layer using Python objects. Pocket will be the unified place to handle file transactions. """ conf_channel = [] for c in self.itervalues(): conf_channel.append(c.jsonconf) conf_pocket = self.jsonconf try: json.dump(conf_channel, open(fn_channel, "w"), indent = 2) json.dump(conf_pocket, open(fn_pocket, "w"), indent = 2) except: raise snserror.config.save logger.info("save configs done")
def set(self, url, post_data, data, headers): if post_data: url_hash = hashlib.sha1(url + '?' + post_data).hexdigest() else: url_hash = hashlib.sha1(url).hexdigest() domain = ".".join(urlparse.urlparse(url)[1].split('.')[-2:]) prefix, i, f = self.files(domain, url_hash) makedirs(prefix) created = time.mktime(time.localtime()) content_type = headers.get('content-type', '').split(';')[0].strip() info = { 'compressed': content_type in COMPRESS_TYPES, 'only_headers': data == -1, 'created': created, 'headers': headers, 'url': url, } if post_data: info['post_data'] = post_data if not info['only_headers']: if info['compressed']: data = zlib.compress(data) with open(f, 'w') as _f: _f.write(data) with open(i, 'w') as _i: json.dump(info, _i)
def save_config(self, fn_channel=DIR_DEFAULT_CONF_CHANNEL, fn_pocket=DIR_DEFAULT_CONF_POCKET): """ Save configs: reverse of load_config Configs can be modified during execution. snsapi components communicate with upper layer using Python objects. Pocket will be the unified place to handle file transactions. """ conf_channel = [] for c in self.itervalues(): conf_channel.append(c.jsonconf) conf_pocket = self.jsonconf try: json.dump(conf_channel, open(fn_channel, "w"), indent=2) json.dump(conf_pocket, open(fn_pocket, "w"), indent=2) except: raise snserror.config.save logger.info("save configs done")
def generate_rasa_training_data(project_id, intent_list, desc="smalltalk") -> int: """ Creates a temporary directory to store the intents needed to train :return: the total of examples to be trained """ from mongo_connector import intents total = 0 examples = [] f = open("kk.txt", "w") fall="intent,button,entities" for intent in tqdm(intent_list, desc=f"[INFO] Processing {desc}"): try: intent_id = intents.read_id_by_name(project_id, intent) exa = intents.read_examples(project_id, intent_id) examples.extend(exa) total = len(examples) if len(exa) > 0: exa0 = exa[0] fall = fall + "\n" + intent + "," + exa0["text"] + "," except TypeError as ex: # Intent does not exist, maybe it is not created but in stories or vice versa continue json.dump( { "rasa_nlu_data": { "common_examples": examples, "regex_features": [], "lookup_tables": [ { "name": "location", "elements": "data/lookup/municipiosaragon.txt" }, { "name": "gastronomy_name", "elements": "data/lookup/restaurantes.txt" }, { "name": "accomodation_name_big", "elements": "data/lookup/hoteles.txt" }, { "name": "accomodation_name", "elements": "data/lookup/hoteles.txt" } ], "entity_synonyms": [], } }, os.path.join(TRAINING_NLU_DATA_DIR, f"training_data.json"), ) f.write(fall) f.close() return total
def new_db(name): if not setting['db_status']: url = setting['url'] engine = create_engine(url) # ,echo =True) conn = engine.connect() conn.execute("commit") try: conn.execute(f"CREATE DATABASE {name}") except Exception as e: print(e) conn.close() setting['db_status'] = 1 with open('setting.json', 'w') as f: json.dump(setting, f)
def save_token(self): ''' access token can be saved, it stays valid for a couple of days if successfully saved, invoke get_saved_token() to get it back ''' fname = self.auth_info.save_token_file if fname == "(default)" : fname = self.jsonconf.channel_name+".token.save" # Do not save expired token (or None type token) if fname != "(null)" and not self.is_expired(): #TODO: encrypt access token token = utils.JsonObject(self.token) with open(fname,"w") as fp: json.dump(token, fp) return True
def save_token(self): ''' access token can be saved, it stays valid for a couple of days if successfully saved, invoke get_saved_token() to get it back ''' token = utils.JsonObject(self.token) #TODO: encrypt access token fname = self.auth_info.save_token_file if fname == "(default)": fname = self.jsonconf.channel_name + ".token.save" if fname != "(null)": with open(fname, "w") as fp: json.dump(token, fp) return True
def escribir_archivo(dic, nombre_archivo, agrega=True): archivo = open(nombre_archivo, agrega and "a" or "w") formatos = [('Encabezado', ENCABEZADO, [dic], 0), ('Observacion', OBSERVACION, dic.get('observaciones', []), 'O'), ('Eventos', ERROR, dic.get('eventos', []), 'V'), ('Error', ERROR, dic.get('errores', []), 'E'), ] if '--json' in sys.argv: json.dump(dic, archivo, sort_keys=True, indent=4) elif '--dbf' in sys.argv: guardar_dbf(formatos, agrega, conf_dbf) else: for nombre, formato, registros, tipo_reg in formatos: for it in registros: it['tipo_reg'] = tipo_reg archivo.write(escribir(it, formato)) archivo.close()
def escribir_archivo(cols, items, nombre_archivo, agrega=False): archivo = open(nombre_archivo, agrega and "a" or "w") ext = os.path.splitext(nombre_archivo)[1] if ext == '.csv': csv_writer = csv.writer(archivo, dialect='excel', delimiter=";") csv_writer.writerows([cols]) csv_writer.writerows([[item[k] for k in cols] for item in items]) elif ext == '.json': json.dump(items, archivo, sort_keys=True, indent=4) elif ext == '.dbf': formatos = [('Encabezado', ENCABEZADO, items), ] guardar_dbf(formatos, True, conf_dbf) elif ext == '.txt': for dic in items: dic['tipo_reg'] = 0 archivo.write(escribir(dic, ENCABEZADO)) else: raise RuntimeError("Extension de archivo desconocida: %s" % ext) archivo.close()
importe = 100.00 wsltv.AgregarBonificacion(porcentaje, importe) else: # cargar un archivo de texto: with open("wsltv.json", "r") as f: wsltv.solicitud = json.load(f, encoding="utf-8") if '--testing' in sys.argv: # mensaje de prueba (no realiza llamada remota), # usar solo si no está operativo, cargo respuesta: wsltv.LoadTestXML("tests/xml/wsltv_aut_test_pdf.xml") import json with open("wsltv.json", "w") as f: json.dump(wsltv.solicitud, f, sort_keys=True, indent=4, encoding="utf-8",) print "Liquidacion: pto_vta=%s nro_cbte=%s tipo_cbte=%s" % ( wsltv.solicitud['liquidacion']['puntoVenta'], wsltv.solicitud['liquidacion']['nroComprobante'], wsltv.solicitud['liquidacion']['tipoComprobante'], ) if not '--dummy' in sys.argv: print "Autorizando..." ret = wsltv.AutorizarLiquidacion() if wsltv.Excepcion: print >> sys.stderr, "EXCEPCION:", wsltv.Excepcion if DEBUG: print >> sys.stderr, wsltv.Traceback print "Errores:", wsltv.Errores
def main(): "Función principal de pruebas (obtener CAE)" import os, time, sys global WSDL, LOCATION DEBUG = '--debug' in sys.argv ws = TrazaProdMed() ws.Username = '******' ws.Password = '******' if '--prod' in sys.argv and not H**O: WSDL = WSDL_PROD print "Usando WSDL:", WSDL sys.argv.pop(sys.argv.index("--prod")) # Inicializo las variables y estructuras para el archivo de intercambio: transacciones = [] errores = [] formatos = [] if '--formato' in sys.argv: print "Formato:" for msg, formato, lista in formatos: comienzo = 1 print "=== %s ===" % msg print "|| %-25s || %-12s || %-5s || %-4s || %-10s ||" % ( "Nombre", "Tipo", "Long.", "Pos(txt)", "Campo(dbf)") claves = [] for fmt in formato: clave, longitud, tipo = fmt[0:3] clave_dbf = dar_nombre_campo_dbf(clave, claves) claves.append(clave_dbf) print "|| %-25s || %-12s || %5d || %4d || %-10s ||" % ( clave, tipo, longitud, comienzo, clave_dbf) comienzo += longitud sys.exit(0) if '--cargar' in sys.argv: if '--dbf' in sys.argv: leer_dbf(formatos[:1], {}) elif '--json' in sys.argv: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".json", "r") d = json.load(archivo) formato[2].extend(d) archivo.close() else: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".txt", "r") for linea in archivo: d = leer(linea, formato[1]) formato[2].append(d) archivo.close() ws.Conectar("", WSDL) if ws.Excepcion: print ws.Excepcion print ws.Traceback sys.exit(-1) # Datos de pruebas: if '--test' in sys.argv: ws.CrearTransaccion( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="7791234567801", gln_destino="7791234567801", n_remito="R0001-12341234", n_factura="A0001-12341234", vencimiento=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="07791234567810", lote=datetime.datetime.now().strftime("%Y"), # R4556567 numero_serial=int(time.time()*10), # A23434 id_evento=1, cuit_medico="30711622507", id_obra_social=465667, apellido="Reingart", nombres="Mariano", tipo_documento="96", n_documento="28510785", sexo="M", calle="San Martin", numero="5656", piso="", depto="1", localidad="Berazategui", provincia="Buenos Aires", n_postal="1700", fecha_nacimiento="20/12/1972", telefono="5555-5555", nro_afiliado="9999999999999", cod_diagnostico="B30", cod_hiv="NOAP31121970", id_motivo_devolucion=1, otro_motivo_devolucion="producto fallado", ) # Opciones principales: if '--cancela' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML("tests/xml/trazaprodmed_cancela_err.xml") # cargo respuesta ws.SendCancelacTransacc(*sys.argv[sys.argv.index("--cancela")+1:]) elif '--cancela_parcial' in sys.argv: ws.SendCancelacTransaccParcial(*sys.argv[sys.argv.index("--cancela_parcial")+1:]) elif '--consulta' in sys.argv: ws.GetTransaccionesWS( *sys.argv[sys.argv.index("--consulta")+1:] ) print "CantPaginas", ws.CantPaginas print "HayError", ws.HayError #print "TransaccionPlainWS", ws.TransaccionPlainWS # parametros comunes de salida (columnas de la tabla): TRANSACCIONES = ws.Transacciones[0].keys() if ws.Transacciones else [] claves = [k for k in TRANSACCIONES] # extiendo la lista de resultado para el archivo de intercambio: transacciones.extend(ws.Transacciones) # encabezado de la tabla: print "||", "||".join(["%s" % clave for clave in claves]), "||" # recorro los datos devueltos (TransaccionPlainWS): while ws.LeerTransaccion(): for clave in claves: print "||", ws.GetParametro(clave), # imprimo cada fila print "||" elif '--catalogo' in sys.argv: ret = ws.GetCatalogoElectronicoByGTIN( *sys.argv[sys.argv.index("--catalogo")+1:] ) for catalogo in ws.params_out.values(): print catalogo # imprimo cada fila else: argv = [argv for argv in sys.argv if not argv.startswith("--")] if not transacciones: if len(argv)>16: ws.CrearTransaccion(*argv[3:]) else: print "ERROR: no se indicaron todos los parámetros requeridos" if ws.Transacciones: try: usuario, password = argv[1:3] except: print "ADVERTENCIA: no se indico parámetros usuario y passoword" usuario = password = "******" ws.InformarProducto(usuario, password) for i, tx in enumerate(transacciones): print "Procesando registro", i tx['codigo_transaccion'] = ws.CodigoTransaccion errores.extend(ws.errores) print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) else: print "ERROR: no se especificaron productos a informar" if ws.Excepcion: print ws.Traceback if '--grabar' in sys.argv: if '--dbf' in sys.argv: guardar_dbf(formatos, True, {}) elif '--json' in sys.argv: for formato in formatos: archivo = open(formato[0].lower() + ".json", "w") json.dump(formato[2], archivo, sort_keys=True, indent=4) archivo.close() else: for formato in formatos: archivo = open(formato[0].lower() + ".txt", "w") for it in formato[2]: archivo.write(escribir(it, formato[1])) archivo.close()
# tributo: codigo_tributo = 99 descripcion = "Ganancias" base_imponible = 15000 alicuota = 8 importe = 1200 wsltv.AgregarTributo(codigo_tributo, descripcion, base_imponible, alicuota, importe) if '--testing' in sys.argv: # mensaje de prueba (no realiza llamada remota), # usar solo si no está operativo, cargo respuesta: wsltv.LoadTestXML("tests/xml/wsltv_aut_test_pdf.xml") import json with open("wsltv.json", "w") as f: json.dump(wsltv.solicitud, f, sort_keys=True, indent=4, encoding="utf-8",) print "Liquidacion: pto_vta=%s nro_cbte=%s tipo_cbte=%s" % ( wsltv.solicitud['liquidacion']['puntoVenta'], wsltv.solicitud['liquidacion']['nroComprobante'], wsltv.solicitud['liquidacion']['tipoComprobante'], ) if not '--dummy' in sys.argv: print "Autorizando..." ret = wsltv.AutorizarLiquidacion() if wsltv.Excepcion: print >> sys.stderr, "EXCEPCION:", wsltv.Excepcion if DEBUG: print >> sys.stderr, wsltv.Traceback print "Errores:", wsltv.Errores
def main(): "Función principal de pruebas (obtener CAE)" import os, time, sys global WSDL, LOCATION DEBUG = '--debug' in sys.argv ws = TrazaMed() ws.Username = '******' ws.Password = '******' if '--prod' in sys.argv and not H**O: WSDL = "https://trazabilidad.pami.org.ar:9050/trazamed.WebService" print "Usando WSDL:", WSDL sys.argv.pop(sys.argv.index("--prod")) # Inicializo las variables y estructuras para el archivo de intercambio: medicamentos = [] transacciones = [] errores = [] formatos = [('Medicamentos', MEDICAMENTOS, medicamentos), ('Transacciones', TRANSACCIONES, transacciones), ('Errores', ERRORES, errores), ] if '--formato' in sys.argv: print "Formato:" for msg, formato, lista in formatos: comienzo = 1 print "=== %s ===" % msg print "|| %-25s || %-12s || %-5s || %-4s || %-10s ||" % ( "Nombre", "Tipo", "Long.", "Pos(txt)", "Campo(dbf)") claves = [] for fmt in formato: clave, longitud, tipo = fmt[0:3] clave_dbf = dar_nombre_campo_dbf(clave, claves) claves.append(clave_dbf) print "|| %-25s || %-12s || %5d || %4d || %-10s ||" % ( clave, tipo, longitud, comienzo, clave_dbf) comienzo += longitud sys.exit(0) if '--cargar' in sys.argv: if '--dbf' in sys.argv: leer_dbf(formatos[:1], {}) elif '--json' in sys.argv: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".json", "r") d = json.load(archivo) formato[2].extend(d) archivo.close() else: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".txt", "r") for linea in archivo: d = leer(linea, formato[1]) formato[2].append(d) archivo.close() ws.Conectar("", WSDL) if ws.Excepcion: print ws.Excepcion print ws.Traceback sys.exit(-1) # Datos de pruebas: if '--test' in sys.argv: medicamentos.append(dict( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="9999999999918", gln_destino="glnws", n_remito="R000100001234", n_factura="A000100001234", vencimiento=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="GTIN1", lote=datetime.datetime.now().strftime("%Y"), numero_serial=int(time.time()*10), id_obra_social=None, id_evento=134, cuit_origen="20267565393", cuit_destino="20267565393", apellido="Reingart", nombres="Mariano", tipo_documento="96", n_documento="26756539", sexo="M", direccion="Saraza", numero="1234", piso="", depto="", localidad="Hurlingham", provincia="Buenos Aires", n_postal="1688", fecha_nacimiento="01/01/2000", telefono="5555-5555", nro_asociado="9999999999999", cantidad=None, desde_numero_serial=None, hasta_numero_serial=None, codigo_transaccion=None, )) if '--testfraccion' in sys.argv: medicamentos.append(dict( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="9999999999918", gln_destino="glnws", n_remito="1234", n_factura="1234", vencimiento=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="GTIN1", lote=datetime.datetime.now().strftime("%Y"), numero_serial=int(time.time()*10), id_obra_social=None, id_evento=134, cuit_origen="20267565393", cuit_destino="20267565393", apellido="Reingart", nombres="Mariano", tipo_documento="96", n_documento="26756539", sexo="M", direccion="Saraza", numero="1234", piso="", depto="", localidad="Hurlingham", provincia="Buenos Aires", n_postal="1688", fecha_nacimiento="01/01/2000", telefono="5555-5555", nro_asociado="9999999999999", cantidad=5, desde_numero_serial=None, hasta_numero_serial=None, codigo_transaccion=None, )) if '--testdh' in sys.argv: medicamentos.append(dict( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="9999999999918", gln_destino="glnws", n_remito="1234", n_factura="1234", vencimiento=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="GTIN1", lote=datetime.datetime.now().strftime("%Y"), desde_numero_serial=int(time.time()*10)-1, hasta_numero_serial=int(time.time()*10)+1, id_obra_social=None, id_evento=134, nro_asociado="1234", cantidad=None, numero_serial=None, codigo_transaccion=None, )) # Opciones principales: if '--cancela' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML("trazamed_cancela_err.xml") # cargo respuesta ws.SendCancelacTransacc(*sys.argv[sys.argv.index("--cancela")+1:]) elif '--cancela_parcial' in sys.argv: ws.SendCancelacTransaccParcial(*sys.argv[sys.argv.index("--cancela_parcial")+1:]) elif '--confirma' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML("trazamed_confirma.xml") # cargo respuesta ok = ws.SendConfirmaTransacc(usuario="pruebasws", password="******", p_ids_transac="1", f_operacion="31-12-2013") if not ok: raise RuntimeError(ws.Excepcion) ws.SendConfirmaTransacc(*sys.argv[sys.argv.index("--confirma")+1:]) elif '--alerta' in sys.argv: ws.SendAlertaTransacc(*sys.argv[sys.argv.index("--alerta")+1:]) elif '--consulta' in sys.argv: if '--alertados' in sys.argv: ws.GetEnviosPropiosAlertados( *sys.argv[sys.argv.index("--alertados")+1:] ) elif '--movimientos' in sys.argv: ws.GetTransaccionesWS( *sys.argv[sys.argv.index("--movimientos")+1:] ) else: ws.GetTransaccionesNoConfirmadas( *sys.argv[sys.argv.index("--consulta")+1:] #usuario="pruebasws", password="******", #p_id_transaccion_global="1234", #id_agente_informador="1", #id_agente_origen="1", #id_agente_destino="1", #id_medicamento="1", #id_evento="1", #fecha_desde_op="01/01/2015", #fecha_hasta_op="31/12/2013", #fecha_desde_t="01/01/2013", #fecha_hasta_t="31/12/2013", #fecha_desde_v="01/04/2013", #fecha_hasta_v="30/04/2013", #n_factura=5, n_remito=6, #estado=1, #lote=88745, #numero_serial=894124788, ) print "CantPaginas", ws.CantPaginas print "HayError", ws.HayError #print "TransaccionPlainWS", ws.TransaccionPlainWS # parametros comunes de salida (columnas de la tabla): claves = [k for k, v, l in TRANSACCIONES] # extiendo la lista de resultado para el archivo de intercambio: transacciones.extend(ws.TransaccionPlainWS) # encabezado de la tabla: print "||", "||".join(["%s" % clave for clave in claves]), "||" # recorro los datos devueltos (TransaccionPlainWS): while ws.LeerTransaccion(): for clave in claves: print "||", ws.GetParametro(clave), # imprimo cada fila print "||" elif '--catalogo' in sys.argv: ret = ws.GetCatalogoElectronicoByGTIN( *sys.argv[sys.argv.index("--catalogo")+1:] ) for catalogo in ret: print ret # imprimo cada fila else: argv = [argv for argv in sys.argv if not argv.startswith("--")] if not medicamentos: if len(argv)>16: if '--dh' in sys.argv: ws.SendMedicamentosDHSerie(*argv[1:]) elif '--fraccion' in sys.argv: ws.SendMedicamentosFraccion(*argv[1:]) else: ws.SendMedicamentos(*argv[1:]) else: print "ERROR: no se indicaron todos los parámetros requeridos" elif medicamentos: try: usuario, password = argv[1:3] except: print "ADVERTENCIA: no se indico parámetros usuario y passoword" usuario = password = "******" for i, med in enumerate(medicamentos): print "Procesando registro", i del med['codigo_transaccion'] if med.get("cantidad"): del med["desde_numero_serial"] del med["hasta_numero_serial"] ws.SendMedicamentosFraccion(usuario, password, **med) elif med.get("desde_numero_serial"): del med["cantidad"] del med["numero_serial"] ws.SendMedicamentosDHSerie(usuario, password, **med) else: del med["cantidad"] del med["desde_numero_serial"] del med["hasta_numero_serial"] ws.SendMedicamentos(usuario, password, **med) med['codigo_transaccion'] = ws.CodigoTransaccion errores.extend(ws.errores) print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) else: print "ERROR: no se especificaron medicamentos a informar" if not medicamentos: print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) if ws.Excepcion: print ws.Traceback if '--grabar' in sys.argv: if '--dbf' in sys.argv: guardar_dbf(formatos, True, {}) elif '--json' in sys.argv: for formato in formatos: archivo = open(formato[0].lower() + ".json", "w") json.dump(formato[2], archivo, sort_keys=True, indent=4) archivo.close() else: for formato in formatos: archivo = open(formato[0].lower() + ".txt", "w") for it in formato[2]: archivo.write(escribir(it, formato[1])) archivo.close()
def main(): "Función principal de pruebas (obtener CAE)" import os, time, sys global WSDL, LOCATION DEBUG = '--debug' in sys.argv ws = TrazaVet() ws.Username = '******' ws.Password = '******' if '--prod' in sys.argv and not H**O: WSDL = "https://servicios.pami.org.ar/trazavet.WebService?wsdl" print "Usando WSDL:", WSDL sys.argv.pop(sys.argv.index("--prod")) if '--proxy' in sys.argv and not H**O: proxy = sys.argv.pop(sys.argv.index("--proxy") + 1) print "Usando proxy:", proxy sys.argv.pop(sys.argv.index("--proxy")) else: proxy = None # Inicializo las variables y estructuras para el archivo de intercambio: transaccion_dto = [] transacciones = [] errores = [] formatos = [('TransaccionDTO', TRANSACCION_DTO, transaccion_dto), ('Transacciones', TRANSACCIONES, transacciones), ('Errores', ERRORES, errores), ] if '--formato' in sys.argv: print "Formato:" for msg, formato, lista in formatos: comienzo = 1 print "=== %s ===" % msg print "|| %-25s || %-12s || %-5s || %-4s || %-10s ||" % ( "Nombre", "Tipo", "Long.", "Pos(txt)", "Campo(dbf)") claves = [] for fmt in formato: clave, longitud, tipo = fmt[0:3] clave_dbf = dar_nombre_campo_dbf(clave, claves) claves.append(clave_dbf) print "|| %-25s || %-12s || %5d || %4d || %-10s ||" % ( clave, tipo, longitud, comienzo, clave_dbf) comienzo += longitud sys.exit(0) if '--cargar' in sys.argv: if '--dbf' in sys.argv: leer_dbf(formatos[:1], {}) elif '--json' in sys.argv: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".json", "r") d = json.load(archivo) formato[2].extend(d) archivo.close() else: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".txt", "r") for linea in archivo: d = leer(linea, formato[1]) formato[2].append(d) archivo.close() ws.Conectar("", WSDL, proxy) if ws.Excepcion: print ws.Excepcion print ws.Traceback sys.exit(-1) # Datos de pruebas: if '--test' in sys.argv: transaccion_dto.append(dict( gln_origen="9876543210982", gln_destino="3692581473693", f_operacion=datetime.datetime.now().strftime("%d/%m/%Y"), f_elaboracion=datetime.datetime.now().strftime("%d/%m/%Y"), f_vto=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), id_evento=11, cod_producto="88900000000001", n_cantidad=1, n_serie=int(time.time()*10), n_lote=datetime.datetime.now().strftime("%Y"), n_cai="123456789012345", n_cae="", id_motivo_destruccion=0, n_manifiesto="", en_transporte="N", n_remito="1234", motivo_devolucion="", observaciones="prueba", n_vale_compra="", apellidoNombres="Juan Peres", direccion="Saraza", numero="1234", localidad="Hurlingham", provincia="Buenos Aires", n_postal="1688", cuit="20267565393", codigo_transaccion=None, )) # Opciones principales: if '--confirma' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML("trazamed_confirma.xml") # cargo respuesta ok = ws.SendConfirmaTransacc(usuario="pruebasws", password="******", p_ids_transac="1", f_operacion="31-12-2013") if not ok: raise RuntimeError(ws.Excepcion) ws.SendConfirmaTransacc(*sys.argv[sys.argv.index("--confirma")+1:]) elif '--alerta' in sys.argv: ws.SendAlertaTransacc(*sys.argv[sys.argv.index("--alerta")+1:]) elif '--cancela' in sys.argv: ws.SendCancelaTransac(*sys.argv[sys.argv.index("--cancela")+1:]) elif '--consulta' in sys.argv: ws.GetTransacciones( *sys.argv[sys.argv.index("--consulta")+1:] ) print "CantPaginas", ws.CantPaginas print "HayError", ws.HayError #print "TransaccionSenasa", ws.TransaccionSenasa # parametros comunes de salida (columnas de la tabla): claves = [k for k, v, l in TRANSACCIONES] # extiendo la lista de resultado para el archivo de intercambio: transacciones.extend(ws.TransaccionSenasa) # encabezado de la tabla: print "||", "||".join(["%s" % clave for clave in claves]), "||" # recorro los datos devueltos (TransaccionSenasa): while ws.LeerTransaccion(): for clave in claves: print "||", ws.GetParametro(clave), # imprimo cada fila print "||" else: argv = [argv for argv in sys.argv if not argv.startswith("--")] if not transaccion_dto: if len(argv)>10: ws.SaveTransaccion(*argv[1:]) else: print "ERROR: no se indicaron todos los parámetros requeridos" elif transaccion_dto: try: usuario, password = argv[-2:] except: print "ADVERTENCIA: no se indico parámetros usuario y passoword" usuario, password = "******", "Clave2013" for i, dto in enumerate(transaccion_dto): print "Procesando registro", i del dto['codigo_transaccion'] ws.SaveTransaccion(usuario, password, **dto) dto['codigo_transaccion'] = ws.CodigoTransaccion errores.extend(ws.errores) print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) else: print "ERROR: no se especificaron productos a informar" if not transaccion_dto: print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) if ws.Excepcion: print ws.Traceback if '--grabar' in sys.argv: if '--dbf' in sys.argv: guardar_dbf(formatos, True, {}) elif '--json' in sys.argv: for formato in formatos: archivo = open(formato[0].lower() + ".json", "w") json.dump(formato[2], archivo, sort_keys=True, indent=4) archivo.close() else: for formato in formatos: archivo = open(formato[0].lower() + ".txt", "w") for it in formato[2]: archivo.write(escribir(it, formato[1])) archivo.close()
tipo_receptor='EM', # 'EM': DEPOSITO EMISOR, 'MI': MERCADO INTERNO, 'RP': REPARTO categoria_receptor=1, id_req=int(time.time()), cuit_receptor='20111111112', cuit_depositario=None, cod_dom_destino=1, cod_rem_redestinar=None, cod_remito=30, ) if "--autorizar" in sys.argv: rec["estado"] = 'A' # 'A': Autorizar, 'D': Denegar rec['viaje'] = dict(cuit_transportista='20333333334', cuit_conductor='20333333334', fecha_inicio_viaje='2018-10-01', distancia_km=999) rec['viaje']['vehiculo'] = dict(dominio_vehiculo='AAA000', dominio_acoplado='ZZZ000') rec['mercaderias'] = [dict(orden=1, tropa=1, cod_tipo_prod='2.13', kilos=10, unidades=1)] rec['datos_autorizacion'] = None # dict(nro_remito=None, cod_autorizacion=None, fecha_emision=None, fecha_vencimiento=None) rec['contingencias'] = [dict(tipo=1, observacion="anulacion")] with open(ENTRADA, "w") as archivo: json.dump(rec, archivo, sort_keys=True, indent=4) if '--cargar' in sys.argv: with open(ENTRADA, "r") as archivo: rec = json.load(archivo) wsremcarne.CrearRemito(**rec) wsremcarne.AgregarViaje(**rec['viaje']) wsremcarne.AgregarVehiculo(**rec['viaje']['vehiculo']) for mercaderia in rec['mercaderias']: wsremcarne.AgregarMercaderia(**mercaderia) datos_aut = rec['datos_autorizacion'] if datos_aut: wsremcarne.AgregarDatosAutorizacion(**datos_aut) for contingencia in rec['contingencias']: wsremcarne.AgregarContingencias(**contingencia)
def main(): "Función principal de pruebas (obtener CAE)" import os, time, sys global WSDL, LOCATION DEBUG = '--debug' in sys.argv ws = TrazaFito() ws.Username = '******' ws.Password = '******' if '--prod' in sys.argv and not H**O: WSDL = "https://servicios.pami.org.ar/trazaagr.WebService?wsdl" print "Usando WSDL:", WSDL sys.argv.pop(sys.argv.index("--prod")) # Inicializo las variables y estructuras para el archivo de intercambio: transaccion_dto = [] transacciones = [] errores = [] formatos = [('TransaccionDTO', TRANSACCION_DTO, transaccion_dto), ('Transacciones', TRANSACCIONES, transacciones), ('Errores', ERRORES, errores), ] if '--formato' in sys.argv: print "Formato:" for msg, formato, lista in formatos: comienzo = 1 print "=== %s ===" % msg print "|| %-25s || %-12s || %-5s || %-4s || %-10s ||" % ( "Nombre", "Tipo", "Long.", "Pos(txt)", "Campo(dbf)") claves = [] for fmt in formato: clave, longitud, tipo = fmt[0:3] clave_dbf = dar_nombre_campo_dbf(clave, claves) claves.append(clave_dbf) print "|| %-25s || %-12s || %5d || %4d || %-10s ||" % ( clave, tipo, longitud, comienzo, clave_dbf) comienzo += longitud sys.exit(0) if '--cargar' in sys.argv: if '--dbf' in sys.argv: leer_dbf(formatos[:1], {}) elif '--json' in sys.argv: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".json", "r") d = json.load(archivo) formato[2].extend(d) archivo.close() else: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".txt", "r") for linea in archivo: d = leer(linea, formato[1]) formato[2].append(d) archivo.close() ws.Conectar("", WSDL) if ws.Excepcion: print ws.Excepcion print ws.Traceback sys.exit(-1) # Datos de pruebas: if '--test' in sys.argv: transaccion_dto.append(dict( gln_origen="9876543210982", gln_destino="3692581473693", f_operacion=datetime.datetime.now().strftime("%d/%m/%Y"), f_elaboracion=datetime.datetime.now().strftime("%d/%m/%Y"), f_vto=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), id_evento=11, cod_producto="88900000000001", n_cantidad=1, n_serie=int(time.time()*10), n_lote=datetime.datetime.now().strftime("%Y"), n_cai="123456789012345", n_cae="", id_motivo_destruccion=0, n_manifiesto="", en_transporte="N", n_remito="1234", motivo_devolucion="", observaciones="prueba", n_vale_compra="", apellidoNombres="Juan Peres", direccion="Saraza", numero="1234", localidad="Hurlingham", provincia="Buenos Aires", n_postal="1688", cuit="20267565393", codigo_transaccion=None, )) # Opciones principales: if '--confirma' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML("trazamed_confirma.xml") # cargo respuesta ok = ws.SendConfirmaTransacc(usuario="pruebasws", password="******", p_ids_transac="1", f_operacion="31-12-2013") if not ok: raise RuntimeError(ws.Excepcion) ws.SendConfirmaTransacc(*sys.argv[sys.argv.index("--confirma")+1:]) elif '--alerta' in sys.argv: ws.SendAlertaTransacc(*sys.argv[sys.argv.index("--alerta")+1:]) elif '--cancela' in sys.argv: ws.SendCancelaTransac(*sys.argv[sys.argv.index("--cancela")+1:]) elif '--consulta' in sys.argv: ws.GetTransacciones( *sys.argv[sys.argv.index("--consulta")+1:] ) print "CantPaginas", ws.CantPaginas print "HayError", ws.HayError #print "TransaccionSenasa", ws.TransaccionSenasa # parametros comunes de salida (columnas de la tabla): claves = [k for k, v, l in TRANSACCIONES] # extiendo la lista de resultado para el archivo de intercambio: transacciones.extend(ws.TransaccionSenasa) # encabezado de la tabla: print "||", "||".join(["%s" % clave for clave in claves]), "||" # recorro los datos devueltos (TransaccionSenasa): while ws.LeerTransaccion(): for clave in claves: print "||", ws.GetParametro(clave), # imprimo cada fila print "||" else: argv = [argv for argv in sys.argv if not argv.startswith("--")] if not transaccion_dto: if len(argv)>10: ws.SaveTransaccion(*argv[1:]) else: print "ERROR: no se indicaron todos los parámetros requeridos" elif transaccion_dto: try: usuario, password = argv[-2:] except: print "ADVERTENCIA: no se indico parámetros usuario y passoword" usuario, password = "******", "Clave2013" for i, dto in enumerate(transaccion_dto): print "Procesando registro", i del dto['codigo_transaccion'] ws.SaveTransaccion(usuario, password, **dto) dto['codigo_transaccion'] = ws.CodigoTransaccion errores.extend(ws.errores) print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) else: print "ERROR: no se especificaron productos a informar" if not transaccion_dto: print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) if ws.Excepcion: print ws.Traceback if '--grabar' in sys.argv: if '--dbf' in sys.argv: guardar_dbf(formatos, True, {}) elif '--json' in sys.argv: for formato in formatos: archivo = open(formato[0].lower() + ".json", "w") json.dump(formato[2], archivo, sort_keys=True, indent=4) archivo.close() else: for formato in formatos: archivo = open(formato[0].lower() + ".txt", "w") for it in formato[2]: archivo.write(escribir(it, formato[1])) archivo.close()
def main(): "Función principal de pruebas (obtener CAE)" import os, time, sys global WSDL, LOCATION DEBUG = '--debug' in sys.argv ws = TrazaProdMed() ws.Username = '******' ws.Password = '******' if '--prod' in sys.argv and not H**O: WSDL = WSDL_PROD print "Usando WSDL:", WSDL sys.argv.pop(sys.argv.index("--prod")) # Inicializo las variables y estructuras para el archivo de intercambio: transacciones = [] errores = [] formatos = [] if '--formato' in sys.argv: print "Formato:" for msg, formato, lista in formatos: comienzo = 1 print "=== %s ===" % msg print "|| %-25s || %-12s || %-5s || %-4s || %-10s ||" % ( "Nombre", "Tipo", "Long.", "Pos(txt)", "Campo(dbf)") claves = [] for fmt in formato: clave, longitud, tipo = fmt[0:3] clave_dbf = dar_nombre_campo_dbf(clave, claves) claves.append(clave_dbf) print "|| %-25s || %-12s || %5d || %4d || %-10s ||" % ( clave, tipo, longitud, comienzo, clave_dbf) comienzo += longitud sys.exit(0) if '--cargar' in sys.argv: if '--dbf' in sys.argv: leer_dbf(formatos[:1], {}) elif '--json' in sys.argv: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".json", "r") d = json.load(archivo) formato[2].extend(d) archivo.close() else: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".txt", "r") for linea in archivo: d = leer(linea, formato[1]) formato[2].append(d) archivo.close() ws.Conectar("", WSDL) if ws.Excepcion: print ws.Excepcion print ws.Traceback sys.exit(-1) # Datos de pruebas: if '--test' in sys.argv: ws.CrearTransaccion( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="7791234567801", gln_destino="7791234567801", n_remito="R0001-12341234", n_factura="A0001-12341234", vencimiento=(datetime.datetime.now() + datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="07791234567810", lote=datetime.datetime.now().strftime("%Y"), # R4556567 numero_serial=int(time.time() * 10), # A23434 id_evento=1, cuit_medico="30711622507", id_obra_social=465667, apellido="Reingart", nombres="Mariano", tipo_documento="96", n_documento="28510785", sexo="M", calle="San Martin", numero="5656", piso="", depto="1", localidad="Berazategui", provincia="Buenos Aires", n_postal="1700", fecha_nacimiento="20/12/1972", telefono="5555-5555", nro_afiliado="9999999999999", cod_diagnostico="B30", cod_hiv="NOAP31121970", id_motivo_devolucion=1, otro_motivo_devolucion="producto fallado", ) # Opciones principales: if '--cancela' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML( "tests/xml/trazaprodmed_cancela_err.xml") # cargo respuesta ws.SendCancelacTransacc(*sys.argv[sys.argv.index("--cancela") + 1:]) elif '--cancela_parcial' in sys.argv: ws.SendCancelacTransaccParcial( *sys.argv[sys.argv.index("--cancela_parcial") + 1:]) elif '--consulta' in sys.argv: ws.GetTransaccionesWS(*sys.argv[sys.argv.index("--consulta") + 1:]) print "CantPaginas", ws.CantPaginas print "HayError", ws.HayError #print "TransaccionPlainWS", ws.TransaccionPlainWS # parametros comunes de salida (columnas de la tabla): TRANSACCIONES = ws.Transacciones[0].keys() if ws.Transacciones else [] claves = [k for k in TRANSACCIONES] # extiendo la lista de resultado para el archivo de intercambio: transacciones.extend(ws.Transacciones) # encabezado de la tabla: print "||", "||".join(["%s" % clave for clave in claves]), "||" # recorro los datos devueltos (TransaccionPlainWS): while ws.LeerTransaccion(): for clave in claves: print "||", ws.GetParametro(clave), # imprimo cada fila print "||" elif '--catalogo' in sys.argv: ret = ws.GetCatalogoElectronicoByGTIN( *sys.argv[sys.argv.index("--catalogo") + 1:]) for catalogo in ws.params_out.values(): print catalogo # imprimo cada fila else: argv = [argv for argv in sys.argv if not argv.startswith("--")] if not transacciones: if len(argv) > 16: ws.CrearTransaccion(*argv[3:]) else: print "ERROR: no se indicaron todos los parámetros requeridos" if ws.Transacciones: try: usuario, password = argv[1:3] except: print "ADVERTENCIA: no se indico parámetros usuario y passoword" usuario = password = "******" ws.InformarProducto(usuario, password) for i, tx in enumerate(transacciones): print "Procesando registro", i tx['codigo_transaccion'] = ws.CodigoTransaccion errores.extend(ws.errores) print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) else: print "ERROR: no se especificaron productos a informar" if ws.Excepcion: print ws.Traceback if '--grabar' in sys.argv: if '--dbf' in sys.argv: guardar_dbf(formatos, True, {}) elif '--json' in sys.argv: for formato in formatos: archivo = open(formato[0].lower() + ".json", "w") json.dump(formato[2], archivo, sort_keys=True, indent=4) archivo.close() else: for formato in formatos: archivo = open(formato[0].lower() + ".txt", "w") for it in formato[2]: archivo.write(escribir(it, formato[1])) archivo.close()
cuit_conductor='20333333334', fecha_inicio_viaje='2018-10-01', distancia_km=999) rec['viaje']['vehiculo'] = dict(dominio_vehiculo='AAA000', dominio_acoplado='ZZZ000') rec['mercaderias'] = [ dict(orden=1, tropa=1, cod_tipo_prod='2.13', kilos=10, unidades=1) ] rec['datos_autorizacion'] = None # dict(nro_remito=None, cod_autorizacion=None, fecha_emision=None, fecha_vencimiento=None) rec['contingencias'] = [dict(tipo=1, observacion="anulacion")] with open(ENTRADA, "w") as archivo: json.dump(rec, archivo, sort_keys=True, indent=4) if '--cargar' in sys.argv: with open(ENTRADA, "r") as archivo: rec = json.load(archivo) wsremcarne.CrearRemito(**rec) wsremcarne.AgregarViaje(**rec['viaje']) wsremcarne.AgregarVehiculo(**rec['viaje']['vehiculo']) for mercaderia in rec['mercaderias']: wsremcarne.AgregarMercaderia(**mercaderia) datos_aut = rec['datos_autorizacion'] if datos_aut: wsremcarne.AgregarDatosAutorizacion(**datos_aut) for contingencia in rec['contingencias']: wsremcarne.AgregarContingencias(**contingencia)
def main(): "Función principal de pruebas (obtener CAE)" import os, time, sys global WSDL, LOCATION DEBUG = '--debug' in sys.argv ws = TrazaMed() ws.Username = '******' ws.Password = '******' if '--prod' in sys.argv and not H**O: WSDL = "https://trazabilidad.pami.org.ar:9050/trazamed.WebService" print "Usando WSDL:", WSDL sys.argv.pop(sys.argv.index("--prod")) # Inicializo las variables y estructuras para el archivo de intercambio: medicamentos = [] transacciones = [] errores = [] formatos = [('Medicamentos', MEDICAMENTOS, medicamentos), ('Transacciones', TRANSACCIONES, transacciones), ('Errores', ERRORES, errores), ] if '--formato' in sys.argv: print "Formato:" for msg, formato, lista in formatos: comienzo = 1 print "=== %s ===" % msg print "|| %-25s || %-12s || %-5s || %-4s || %-10s ||" % ( "Nombre", "Tipo", "Long.", "Pos(txt)", "Campo(dbf)") claves = [] for fmt in formato: clave, longitud, tipo = fmt[0:3] clave_dbf = dar_nombre_campo_dbf(clave, claves) claves.append(clave_dbf) print "|| %-25s || %-12s || %5d || %4d || %-10s ||" % ( clave, tipo, longitud, comienzo, clave_dbf) comienzo += longitud sys.exit(0) if '--cargar' in sys.argv: if '--dbf' in sys.argv: leer_dbf(formatos[:1], {}) elif '--json' in sys.argv: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".json", "r") d = json.load(archivo) formato[2].extend(d) archivo.close() else: for formato in formatos[:1]: archivo = open(formato[0].lower() + ".txt", "r") for linea in archivo: d = leer(linea, formato[1]) formato[2].append(d) archivo.close() ws.Conectar("", WSDL) if ws.Excepcion: print ws.Excepcion print ws.Traceback sys.exit(-1) # Datos de pruebas: if '--test' in sys.argv: medicamentos.append(dict( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="9999999999918", gln_destino="glnws", n_remito="R000100001234", n_factura="A000100001234", vencimiento=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="GTIN1", lote=datetime.datetime.now().strftime("%Y"), numero_serial=int(time.time()*10), id_obra_social=None, id_evento=134, cuit_origen="20267565393", cuit_destino="20267565393", apellido="Reingart", nombres="Mariano", tipo_documento="96", n_documento="26756539", sexo="M", direccion="Saraza", numero="1234", piso="", depto="", localidad="Hurlingham", provincia="Buenos Aires", n_postal="1688", fecha_nacimiento="01/01/2000", telefono="5555-5555", nro_asociado="9999999999999", cantidad=None, desde_numero_serial=None, hasta_numero_serial=None, codigo_transaccion=None, )) if '--testfraccion' in sys.argv: medicamentos.append(dict( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="9999999999918", gln_destino="glnws", n_remito="1234", n_factura="1234", vencimiento=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="GTIN1", lote=datetime.datetime.now().strftime("%Y"), numero_serial=int(time.time()*10), id_obra_social=None, id_evento=134, cuit_origen="20267565393", cuit_destino="20267565393", apellido="Reingart", nombres="Mariano", tipo_documento="96", n_documento="26756539", sexo="M", direccion="Saraza", numero="1234", piso="", depto="", localidad="Hurlingham", provincia="Buenos Aires", n_postal="1688", fecha_nacimiento="01/01/2000", telefono="5555-5555", nro_asociado="9999999999999", cantidad=5, desde_numero_serial=None, hasta_numero_serial=None, codigo_transaccion=None, )) if '--testdh' in sys.argv: medicamentos.append(dict( f_evento=datetime.datetime.now().strftime("%d/%m/%Y"), h_evento=datetime.datetime.now().strftime("%H:%M"), gln_origen="9999999999918", gln_destino="glnws", n_remito="1234", n_factura="1234", vencimiento=(datetime.datetime.now()+datetime.timedelta(30)).strftime("%d/%m/%Y"), gtin="GTIN1", lote=datetime.datetime.now().strftime("%Y"), desde_numero_serial=int(time.time()*10)-1, hasta_numero_serial=int(time.time()*10)+1, id_obra_social=None, id_evento=134, nro_asociado="1234", cantidad=None, numero_serial=None, codigo_transaccion=None, )) # Opciones principales: if '--cancela' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML("trazamed_cancela_err.xml") # cargo respuesta ws.SendCancelacTransacc(*sys.argv[sys.argv.index("--cancela")+1:]) elif '--cancela_parcial' in sys.argv: ws.SendCancelacTransaccParcial(*sys.argv[sys.argv.index("--cancela_parcial")+1:]) elif '--confirma' in sys.argv: if '--loadxml' in sys.argv: ws.LoadTestXML("trazamed_confirma.xml") # cargo respuesta ok = ws.SendConfirmaTransacc(usuario="pruebasws", password="******", p_ids_transac="1", f_operacion="31-12-2013") if not ok: raise RuntimeError(ws.Excepcion) ws.SendConfirmaTransacc(*sys.argv[sys.argv.index("--confirma")+1:]) elif '--alerta' in sys.argv: ws.SendAlertaTransacc(*sys.argv[sys.argv.index("--alerta")+1:]) elif '--consulta' in sys.argv: if '--alertados' in sys.argv: ws.GetEnviosPropiosAlertados( *sys.argv[sys.argv.index("--alertados")+1:] ) elif '--movimientos' in sys.argv: ws.GetTransaccionesWS( *sys.argv[sys.argv.index("--movimientos")+1:] ) else: ws.GetTransaccionesNoConfirmadas( *sys.argv[sys.argv.index("--consulta")+1:] #usuario="pruebasws", password="******", #p_id_transaccion_global="1234", #id_agente_informador="1", #id_agente_origen="1", #id_agente_destino="1", #id_medicamento="1", #id_evento="1", #fecha_desde_op="01/01/2015", #fecha_hasta_op="31/12/2013", #fecha_desde_t="01/01/2013", #fecha_hasta_t="31/12/2013", #fecha_desde_v="01/04/2013", #fecha_hasta_v="30/04/2013", #n_factura=5, n_remito=6, #estado=1, #lote=88745, #numero_serial=894124788, ) print "CantPaginas", ws.CantPaginas print "HayError", ws.HayError #print "TransaccionPlainWS", ws.TransaccionPlainWS # parametros comunes de salida (columnas de la tabla): claves = [k for k, v, l in TRANSACCIONES] # extiendo la lista de resultado para el archivo de intercambio: transacciones.extend(ws.TransaccionPlainWS) # encabezado de la tabla: print "||", "||".join(["%s" % clave for clave in claves]), "||" # recorro los datos devueltos (TransaccionPlainWS): while ws.LeerTransaccion(): for clave in claves: print "||", ws.GetParametro(clave), # imprimo cada fila print "||" elif '--catalogo' in sys.argv: ret = ws.GetCatalogoElectronicoByGTIN( *sys.argv[sys.argv.index("--catalogo")+1:] ) for catalogo in ws.params_out.values(): print catalogo # imprimo cada fila elif '--stock' in sys.argv: ret = ws.GetConsultaStock( *sys.argv[sys.argv.index("--stock")+1:] ) print "\n".join([str(s) for s in ws.params_out.values()]) else: argv = [argv for argv in sys.argv if not argv.startswith("--")] if not medicamentos: if len(argv)>16: if '--dh' in sys.argv: ws.SendMedicamentosDHSerie(*argv[1:]) elif '--fraccion' in sys.argv: ws.SendMedicamentosFraccion(*argv[1:]) else: ws.SendMedicamentos(*argv[1:]) else: print "ERROR: no se indicaron todos los parámetros requeridos" elif medicamentos: try: usuario, password = argv[1:3] except: print "ADVERTENCIA: no se indico parámetros usuario y passoword" usuario = password = "******" for i, med in enumerate(medicamentos): print "Procesando registro", i del med['codigo_transaccion'] if med.get("cantidad"): del med["desde_numero_serial"] del med["hasta_numero_serial"] ws.SendMedicamentosFraccion(usuario, password, **med) elif med.get("desde_numero_serial"): del med["cantidad"] del med["numero_serial"] ws.SendMedicamentosDHSerie(usuario, password, **med) else: del med["cantidad"] del med["desde_numero_serial"] del med["hasta_numero_serial"] ws.SendMedicamentos(usuario, password, **med) med['codigo_transaccion'] = ws.CodigoTransaccion errores.extend(ws.errores) print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) else: print "ERROR: no se especificaron medicamentos a informar" if not medicamentos: print "|Resultado %5s|CodigoTransaccion %10s|Errores|%s|" % ( ws.Resultado, ws.CodigoTransaccion, '|'.join(ws.Errores or []), ) if ws.Excepcion: print ws.Traceback if '--grabar' in sys.argv: if '--dbf' in sys.argv: guardar_dbf(formatos, True, {}) elif '--json' in sys.argv: for formato in formatos: archivo = open(formato[0].lower() + ".json", "w") json.dump(formato[2], archivo, sort_keys=True, indent=4) archivo.close() else: for formato in formatos: archivo = open(formato[0].lower() + ".txt", "w") for it in formato[2]: archivo.write(escribir(it, formato[1])) archivo.close()
wslum.AgregarRemito(nro_remito="123456789012") wslum.AgregarRemito(nro_remito="123456789") else: # cargar un archivo de texto: with open("wslum.json", "r") as f: wslum.solicitud = json.load(f, encoding="utf-8") if '--testing' in sys.argv: # mensaje de prueba (no realiza llamada remota), # usar solo si no está operativo, cargo respuesta: wslum.LoadTestXML("tests/xml/wslum_liq_test_pdf_response.xml") import json with open("wslum.json", "w") as f: json.dump(wslum.solicitud, f, sort_keys=True, indent=4, encoding="utf-8",) print "Liquidacion: pto_vta=%s nro_cbte=%s tipo_cbte=%s" % ( wslum.solicitud['liquidacion']['puntoVenta'], wslum.solicitud['liquidacion']['nroComprobante'], wslum.solicitud['liquidacion']['tipoComprobante'], ) if not '--dummy' in sys.argv: print "Autorizando..." ret = wslum.AutorizarLiquidacion() if wslum.Excepcion: print >> sys.stderr, "EXCEPCION:", wslum.Excepcion if DEBUG: print >> sys.stderr, wslum.Traceback print "Errores:", wslum.Errores
wslsp.AgregarTributo(cod_tributo=3, importe=397) else: # cargar un archivo de texto: with open("wslsp.json", "r") as f: wslsp.solicitud = json.load(f, encoding="utf-8") if '--testing' in sys.argv: # mensaje de prueba (no realiza llamada remota), # usar solo si no está operativo, cargo respuesta: wslsp.LoadTestXML("tests/xml/wslsp_liq_test_response.xml") import json with open("wslsp.json", "w") as f: json.dump( wslsp.solicitud, f, sort_keys=True, indent=4, encoding="utf-8", ) print "Liquidacion: pto_vta=%s nro_cbte=%s tipo_cbte=%s" % ( wslsp.solicitud['emisor']['puntoVenta'], wslsp.solicitud['emisor']['nroComprobante'], wslsp.solicitud['emisor']['tipoComprobante'], ) if not '--dummy' in sys.argv: print "Autorizando..." ret = wslsp.AutorizarLiquidacion() if wslsp.Excepcion:
Session = sessionmaker(bind=engine) # 定义映射类User,其继承上一步创建的Base class Price(Base): __tablename__ = 'price' id = Column(INT, primary_key=True, autoincrement=True) gid = Column(INT) price = Column(FLOAT(precision=12)) common_price = Column(FLOAT(precision=12)) expect_price = Column(FLOAT(precision=12)) date_time = Column(DATETIME) class storeUrls(Base): __tablename__ = 'urls' id = Column(INT, primary_key=True, autoincrement=True) url = Column(VARCHAR(100)) goods = Column(VARCHAR(500)) origin_time = Column(DATETIME) setting = Column(INT) if not setting['db_status']: Base.metadata.create_all(engine) setting['db_status'] = 1 with open('setting.json', 'w') as f: json.dump(setting, f) if __name__ == '__main__': # 建表 Base.metadata.create_all(engine)