Hola:
Existe en Habour, MiniGW o Xailer, una función para el redondeo bancario?
Cambia la forma de redondear según la siguiente liga:
https://msdn.microsoft.com/es-mx/librar ... -snippet-2
Gracias de antemano.
In order for this site to work correctly we need to store a small file (called a cookie) on your computer. Most every site in the world does this, however since the 25th of May 2011, by law we have to get your permission first. Please abandon the forum if you disagree.
Para que este foro funcione correctamente es necesario guardar un pequeño fichero (llamado cookie) en su ordenador. La mayoría de los sitios de Internet lo hacen, no obstante desde el 25 de Marzo de 2011 y por ley, necesitamos de su permiso con antelación. Abandone este foro si no está conforme.
Para que este foro funcione correctamente es necesario guardar un pequeño fichero (llamado cookie) en su ordenador. La mayoría de los sitios de Internet lo hacen, no obstante desde el 25 de Marzo de 2011 y por ley, necesitamos de su permiso con antelación. Abandone este foro si no está conforme.
Redondeo Bancario
Re: Redondeo Bancario
Hola Ramon:
Una funcion podria ser esta:
No la he pulido mucho pero creo que funciona a partir de 0,5 redondea al alza que creo que es lo que buscas.
Saludos
Jose
Una funcion podria ser esta:
No la he pulido mucho pero creo que funciona a partir de 0,5 redondea al alza que creo que es lo que buscas.
Código: Seleccionar todo
FUNCTION RoundBan( nCantidad )
LOCAL nEntero, nDecimal, nPos
LOCAL cNumero
cNumero :=Str(nCantidad)
nPos := RAt(".",cNumero)
nEntero := Val( SubStr(cNumero,1,nPos-1) )
nDecimal := Val( SubStr(cNumero,nPos+1,1 ) )
if (ndecimal >=5)
nDecimal := 1
Else
nDecimal := 0
Endif
nCantidad := nEntero + nDecimal
RETURN nCantidad
Jose
Re: Redondeo Bancario
Perdon , no habia visto que 100.5 debe ser 100
creo que asi...
creo que asi...
Código: Seleccionar todo
FUNCTION RoundBan( nCantidad )
LOCAL nEntero, nDecimal, nPos
LOCAL cNumero
cNumero :=Str(nCantidad)
nPos := RAt(".",cNumero)
nEntero := Val( SubStr(cNumero,1,nPos-1) )
nDecimal := Val( SubStr(cNumero,nPos+1,1 ) )
IF (nDecimal > 5 )
nDecimal := 1
ELSEIF (nDecimal == 5 )
IF (SubStr(cNumero,nPos-1,1)!="0")
nDecimal := 1
ELSE
nDecimal := 0
ENDIF
ELSE
nDecimal := 0
ENDIF
nCantidad := nEntero + nDecimal
RETURN nCantidad