Clipper On Line • Ver Tópico - Atenção "SEM GTIN" na entrada dos produtos.

Atenção "SEM GTIN" na entrada dos produtos.

Discussão sobre desenvolvimento de software para atender as exigências da legislação fiscal e tributária (ECF, TEF, SINTEGRA, NF-e, ECD, EFD, etc.)

Moderador: Moderadores

 

Atenção "SEM GTIN" na entrada dos produtos.

Mensagempor JSystem » 14 Mai 2019 23:42

Jairo,

Fiz as mudanças, porém não deu certo, segue abaixo o código, percebi que retorna .T. qualquer numero que digitar, desde que o último dígito seja 0.

Func ValidaGTIN( cCodGtin )

Local nPosi       := 0
Local nDigito     := 0
Local nSomatoria  := 0
Local aAlgoritmo  := {}
Local lRetorno    := .F.

aAlgoritmo := { 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3 }

cCodGtin := AllTrim( str(cCodGtin,14) )

If ( Val( cCodGtin ) <= 0 ) .Or. !( StrZero( Len( cCodGtin ), 2 ) $ [08,12,13,14] )
    Return lRetorno
Else
    nPosi := ( ( 14 - Len( cCodGtin ) ) + 1 )
EndIf

For x := 1 To ( Len( cCodGtin ) - 1 )
     nSomatoria += ( Val( SubStr( cCodGtin, x, 1 ) ) * aAlgoritmo[ nPosi ] )
     nPosi++
Next

// nDigito := Val( Right( Hb_NToS( nSomatoria ), 1 ) )
nDigito := Val( Right( LTrim( Str(nSomatoria,1) ), 1 ) )
If nDigito != 0
    nDigito := ( 10 - nDigito )
EndIf

lRetorno := ( LTrim( Str(nDigito,1) ) = Right( cCodGtin, 1 ) )

Return lRetorno


Segue três códigos de barras válidos de produtos que consegui emitir NFe, caso queira testar:

7898584070440 - Apenas este retorna .T.
7898584070457
7898584070464

Se puder me ajudar ficarei grato.

Att.
JSystem
Usuário Nível 3

Usuário Nível 3
 
Mensagens: 143
Data de registro: 21 Jan 2010 20:10
Cidade/Estado: Uberaba
Curtiu: 3 vezes
Mens.Curtidas: 1 vez

Atenção "SEM GTIN" na entrada dos produtos.

Mensagempor Jairo Maia » 15 Mai 2019 09:12

Olá JSystem,

Você fez confusão ao alterar as linhas 11 e 25 da função e tirou a funcionalidade dela. Pela linha 11, percebe-se que você envia o GTIN numérico, e não caractere. Alterei a função para tratar se envia numérico ou caractere, e está compatível com Clipper. Use essa função:
Func ValidaGTIN( cCodGtin )

Local nPosi       := 0
Local nDigito     := 0
Local nSomatoria  := 0
Local aAlgoritmo  := {}
Local lRetorno    := .F.

aAlgoritmo := { 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3 }

If ValType( cCodGtin ) = "N"
  cCodGtin := AllTrim( Str( cCodGtin ) )
Else
  cCodGtin := AllTrim( cCodGtin )
EndIf

If ( Val( cCodGtin ) <= 0 ) .Or. !( StrZero( Len( cCodGtin ), 2 ) $ [08,12,13,14] )
    Return lRetorno
Else
    nPosi := ( ( 14 - Len( cCodGtin ) ) + 1 )
EndIf

For x := 1 To ( Len( cCodGtin ) - 1 )
     nSomatoria += ( Val( SubStr( cCodGtin, x, 1 ) ) * aAlgoritmo[ nPosi ] )
     nPosi++
Next

nDigito := Val( Right( LTrim( Str( nSomatoria ) ), 1 ) )
If nDigito != 0
    nDigito := ( 10 - nDigito )
EndIf

lRetorno := ( LTrim( Str(nDigito,1) ) = Right( cCodGtin, 1 ) )

Return lRetorno
Abraços, Jairo
Harbour / Clipper 5.2e - Blinker 7
(Não respondo dúvidas por MP ou E-mail. Por favor, não encaminhe via mensagem privada ou e-mail, dúvidas que podem ser compartilhadas com todos no fórum)
Avatar de usuário

Jairo Maia
Colaborador

Colaborador
 
Mensagens: 2733
Data de registro: 16 Ago 2010 13:46
Cidade/Estado: Campinas-SP
Curtiu: 371 vezes
Mens.Curtidas: 305 vezes

Atenção "SEM GTIN" na entrada dos produtos.

Mensagempor JSystem » 15 Mai 2019 18:56

Olá Jairo,

Novamente te dando trabalho, vai tendo um pouco de paciência rsrs.

Substitui a função, porém a falha continua, retornando .T. apenas para os códigos de barras terminados com o número 0, inclusive testei o seguinte, 9999999999990, retornou .T.
JSystem
Usuário Nível 3

Usuário Nível 3
 
Mensagens: 143
Data de registro: 21 Jan 2010 20:10
Cidade/Estado: Uberaba
Curtiu: 3 vezes
Mens.Curtidas: 1 vez

Atenção "SEM GTIN" na entrada dos produtos.

Mensagempor JSystem » 16 Mai 2019 08:41

Olá Pessoal,

Até que o Jairo atenha condição de me retornar, alguém mais utiliza a função e pode me orientar acerca dessa falha ?

Grato.
JSystem
Usuário Nível 3

Usuário Nível 3
 
Mensagens: 143
Data de registro: 21 Jan 2010 20:10
Cidade/Estado: Uberaba
Curtiu: 3 vezes
Mens.Curtidas: 1 vez

Atenção "SEM GTIN" na entrada dos produtos.

Mensagempor Jairo Maia » 16 Mai 2019 10:06

Olá JSystem,

Sua primeira alteração realmente estava com problema, mas fiz as correções e funcionou corretamente. Não vejo razão por ser Clipper e estar dando o problema, acho que você está fazendo algo errado, e ai só você para saber mesmo. Compile o exemplo abaixo em Clipper e veja que resultado retorna:
CLS
?
? ValidaGTIN( Val( "7898584070440" ) )
? ValidaGTIN( Val( "7898584070457" ) )
? ValidaGTIN( Val( "7898584070464" ) )
?

Func ValidaGTIN( cCodGtin )

Local nPosi       := 0
Local nDigito     := 0
Local nSomatoria  := 0
Local aAlgoritmo  := {}
Local lRetorno    := .F.

aAlgoritmo := { 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3, 1, 3 }

If ValType( cCodGtin ) = "N"
  cCodGtin := AllTrim( Str( cCodGtin ) )
Else
  cCodGtin := AllTrim( cCodGtin )
EndIf

If ( Val( cCodGtin ) <= 0 ) .Or. !( StrZero( Len( cCodGtin ), 2 ) $ [08,12,13,14] )
    Return lRetorno
Else
    nPosi := ( ( 14 - Len( cCodGtin ) ) + 1 )
EndIf

For x := 1 To ( Len( cCodGtin ) - 1 )
     nSomatoria += ( Val( SubStr( cCodGtin, x, 1 ) ) * aAlgoritmo[ nPosi ] )
     nPosi++
Next

nDigito := Val( Right( LTrim( Str( nSomatoria ) ), 1 ) )
If nDigito != 0
    nDigito := ( 10 - nDigito )
EndIf

lRetorno := ( LTrim( Str(nDigito,1) ) = Right( cCodGtin, 1 ) )

Return lRetorno
Abraços, Jairo
Harbour / Clipper 5.2e - Blinker 7
(Não respondo dúvidas por MP ou E-mail. Por favor, não encaminhe via mensagem privada ou e-mail, dúvidas que podem ser compartilhadas com todos no fórum)
Avatar de usuário

Jairo Maia
Colaborador

Colaborador
 
Mensagens: 2733
Data de registro: 16 Ago 2010 13:46
Cidade/Estado: Campinas-SP
Curtiu: 371 vezes
Mens.Curtidas: 305 vezes

Atenção "SEM GTIN" na entrada dos produtos.

Mensagempor JSystem » 17 Mai 2019 22:40

Olá Jairo,

Depois de bastante tempo e apanhar bastante, descobri que o problema era na variável de ambiente, set fixed on, foi só desativar funcionou perfeito.

Obrigado pela atenção e paciência.

Grato.
JSystem
Usuário Nível 3

Usuário Nível 3
 
Mensagens: 143
Data de registro: 21 Jan 2010 20:10
Cidade/Estado: Uberaba
Curtiu: 3 vezes
Mens.Curtidas: 1 vez

Anterior



Retornar para Legislação Fiscal e Tributária

Quem está online

Usuários vendo este fórum: Nenhum usuário registrado online e 2 visitantes


Ola Amigo, espero que meu site e forum tem lhe beneficiado, com exemplos e dicas de programacao.
Entao divulgue o link da Doacao abaixo para seus amigos e redes sociais ou faça uma doacao para o site forum...
MUITO OBRIGADO PELA SUA DOACAO!
Faça uma doação para o forum
cron
v
Olá visitante, seja bem-vindo ao Fórum Clipper On Line!
Efetue o seu login ou faça o seu Registro