Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 01-08-2014
rodrinig rodrinig is offline
Miembro
 
Registrado: dic 2007
Posts: 28
Poder: 0
rodrinig Va por buen camino
Ean-13 Convertir A Integer

Hola foro, tengo una duda y queria saber si alguien puede tirarme una soga (de ayuda)

estoy desarrollando un sistema, que ya tienen una base de datos, una de sus tablas (socio) tiene el Nro de socio :

Ejem: 16888
y tienen un carnet con un codigo de barra (que lo unico que se es que esta en ean-13 ) y el nro es
Ejem :000093302426

ahora es la consulta ..... tengo el lector que lee ese codigo pero como hago para convertirlo en el Nro de socio ?
y viceversa.

Espero haber sido claro, y tambien (si se puede) espero una mano.

Desde ya Muchas Gracias.

Rodrigo
Responder Con Cita
  #2  
Antiguo 01-08-2014
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.269
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por rodrinig Ver Mensaje
tengo el lector que lee ese codigo pero como hago para convertirlo en el Nro de socio ?
y viceversa.
Tendrás que tener en algún sitio asociados el número_socio y cod_barra_carnet.
Lo lógico es que como ya tienen una tabla de SOCIOS en la base de datos con el NUMERO_SOCIO, tengan ahí un campo con el COD_BARRA_CARNET, de forma que puedas hacer búsquedas por uno o por otro.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #3  
Antiguo 01-08-2014
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola rodrinig.

Este enlace, explica detalladamente como interpretar el código EAN-13 e inclusive presenta algorítmos para obtener el dígito verificador en varios lenguajes (Delphi incluído).

El European Article Number consta de 13 dígitos, pero el número de tu ejemplo: 000093302426 posee 12, así que no creo que debas interpretarlo de acuerdo a ese protocolo.

Quizá haya que estudiar la posible relación entre ambas cífras con más detenimiento. Pero a esta hora de la noche, sólo se me ocurre su razón matemática: 5524,776527711985 (o más lógicamente que los códigos estén almacenados en una tabla de relaciones).

Saludos

Edito: Publicamos casi al mismo tiempo con Neftali y creo que ambos apuntamos a que la relación sea arbitraria (no matemática). Es decir, que los respectivos códigos residan como campos de un registro de alguna tabla que deja establecida la relación.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 01-08-2014 a las 09:35:16.
Responder Con Cita
  #4  
Antiguo 01-08-2014
engranaje engranaje is offline
Miembro
 
Registrado: may 2011
Posts: 163
Poder: 13
engranaje Va por buen camino
En cierta ocasión yo desarrollé un aplicación similar pero para la que se me había pedido explicitamente que no pudiera averiguarse facilmente con que número de socio se identificaba el código de barras ni aún con acceso a la bd.
El caso es que lo itenté y creo que lo conseguí, precisamente realizando cálculos matemáticos pero lo suficientemente enrevesados como para que valiera la pena pillar la aplicación, todos los carnets, el lector e ir pasandolos uno a uno y apuntando con que socio se relaciona cada código de barras.

Espero que no sea el caso pero si lo fuera y no son demasiados igual te ves obligado a crearte tú una tabla que relacione cada número de socio con su código de barras y rellenarla "a mano".

La cosa es que si no tienes los fuentes de la aplicación que genera los códigos de barras y debes de convivir con ella, supongo que es posible que cuando se dean de alta nuevos socios aparezcan nuevos códigos de barras y tendras que irlos registrando uno a uno en tu nueva tabla. En fin, espero que al final sea todo mas sencillo.
Responder Con Cita
  #5  
Antiguo 04-08-2014
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.734
Poder: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Por lo que comentas, hay una relacion, uno a uno, entre nro. de socio y codigo EAN13 de su carnet.
Por lo tanto, deberás tener una tabla que relaciones estos dos datos, o en la misma tabla de socios, agregar un campo para el nro. de carnet (EAN13).
Dado que un socio puede perder el carnet y deberás darle otro, y querras marcar el "perdido" como inactivo, para que quien lo encuentre no pueda hacerse pasar por socio, te recomiendo la primera opción.
Código:
// Ejemplo de tabla con un socio con dos carnets, pero uno inactivo.
SOCIO CARNET ACTIVO
123   1234567890123   1
234   6549876543214   1
234   9876543546987   0
Lo único que debes tener en cuenta es si el lector te devuelve los 13 dígtos del carnet o solo los 12 que forman el código (el 13vo es código de control).
Incluso podrías guardar el nro. de carnet como un string, ya que todos tendrán la misma longitud.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Error al convertir Edit a Integer 5TU4RT OOP 13 20-04-2012 01:11:32
convertir un tbitmap a integer sultan Gráficos 5 26-10-2008 20:41:56
convertir un integer en hh:mm:ss jmlifi SQL 1 02-11-2005 18:00:44
Convertir un String a Integer Rafe Varios 2 12-08-2005 17:43:38
convertir a integer acrophet Varios 1 03-11-2003 12:01:43


La franja horaria es GMT +2. Ahora son las 21:27:49.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi