Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 23-02-2008
IVAND IVAND is offline
Miembro
 
Registrado: may 2003
Ubicación: ECUADOR
Posts: 529
Poder: 22
IVAND Va por buen camino
la funcion round no funciona en fastreport ?

Hola a todos alguien me podria ayudar sobre el correcto uso de la funcion round en fastreport 2.5 yo lo uso asi y no funciona et
este valor va en dentro del memo

[round([Imp_partes."TOTAL_LINEA"],2)], pero me sigue enviando 4 decimales cuando quiero que solo me muestre dos , lo que necesito hacer es que en una factura las lineas tengan cuatro decimales y al final la suma del importe sea redondeada a 2 decimales , lo consigo hacer mediante la opcion de formateo pero cuando tomo ese valor para un calculo me muestra otra vez los cuatro decimales


Gracias por su interes
__________________
IVAND
Responder Con Cita
  #2  
Antiguo 23-02-2008
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
Ya se ha dicho otras veces: Al menos en españa no es legal redondear importes intermedios. Para los cálculos, debes usar todos los decimales, solo puedes redondear el importe total a pagar.

Por tanto, como lo haces ahora, es como debe hacerse. Muestras 2 decimales en la Base imponible, pero usas los 4 decimales para calcular el IVA (si procede) y el importe total.

Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #3  
Antiguo 23-02-2008
IVAND IVAND is offline
Miembro
 
Registrado: may 2003
Ubicación: ECUADOR
Posts: 529
Poder: 22
IVAND Va por buen camino
Gracias Lepe por tu respuesta pero fijate que no aca en ecuador el calculo del Iva se lo realiza en base a la las base imponible es decir 12.9566 seria igual a 12.96 y el Iva sera calculado en base a esta base (12.96*12/100) , pero ahi es donde esta mi problema porque uso la funcion round de fastreport pero esta no arroja el valor redondeado

Gracias de antemano

Nota : como puedo colocar mis propias funciones en fastreport , porque algo tiene que pasa con el dichoso round o no lo uso bien o no esta funcionando para nada
__________________
IVAND
Responder Con Cita
  #4  
Antiguo 23-02-2008
Avatar de Lepe
[Lepe] Lepe is offline
Miembro Premium
 
Registrado: may 2003
Posts: 7.424
Poder: 29
Lepe Va por buen camino
Lo siento pero sólo usé 4 días el FastReport y no llegué a realizar cálculos de ese tipo. Espero que otra persona te pueda ayudar.

Lo único que puedo sugerirte es que grabes todo en la base de datos, la Base Imponible no tiene por qué calcularse cada vez que quieras imprimir la Factura, si ya está guardado todos los importes, mucho mejor (a mi parecer).

Saludos
__________________
Si usted entendió mi comentario, contácteme y gustosamente,
se lo volveré a explicar hasta que no lo entienda, Gracias.
Responder Con Cita
  #5  
Antiguo 24-02-2008
IVAND IVAND is offline
Miembro
 
Registrado: may 2003
Ubicación: ECUADOR
Posts: 529
Poder: 22
IVAND Va por buen camino
Totalmente de acuerdo con tu comentario y asi lo hago lo que pasa es que la factura la divido en (n) partes por cuestiones de formato de la factura del cliente pero bueno ya esta solucionado el problema
asi que ahi le va la explicacion para los posibles amigos con esta misma inquietud


1.- definimos una unidad en nuestya aplicacion que llamaremos uFastReportFunctions (Es el mismo ejemplo de una funcion creada en una pagina )

copiamos esta funcion completa

Código Delphi [-]
unit uFastReportFunctions;

interface
uses
  Windows, Classes, SysUtils, FR_Class, FR_Const, FR_Utils;

type
  TReportFunctionLibrary = class(TfrFunctionLibrary)
  private
    function RoundD(x: Extended; d: Integer): Double;
  public

    constructor Create; override;
//    procedure dofunctio1(x: Extended; d: Integer); override;
    procedure DoFunction(FNo: Integer; p1, p2, p3: Variant;
      var val: Variant); override;
  end;

implementation
uses
  DB, DBClient, Variants, StrUtils, Math;

{ TReportFunctionLibrary }

constructor TReportFunctionLibrary.Create;
begin
  inherited;
  inherited Create;

// Todas las funciones que se quieran añadir al FR se declaran aquí
  with List do
  begin
    Add('roundd');
  end;

// Para que sean públicas en el apartado Functions del FR se declaran en
// el AddFunctionDesc

  AddFunctionDesc('Roundd', 'MisFunciones', 'FR_ROUNDD(,)/Redondear valores (Devolviendo 1)');
end;

procedure TReportFunctionLibrary.DoFunction(FNo: Integer; p1, p2,
  p3: Variant; var val: Variant);
begin
  inherited;
  val := RoundD(frParser.Calc(p1),frParser.Calc(p2));

// Todas las funciones que se declaren en el create se definen aquí

  //case FNo of
  //  0: val := GetImageType(frParser.Calc(p1), frParser.Calc(p2));
  //end;
end;



function TReportFunctionLibrary.RoundD(x: Extended; d: Integer): Double;
var
  n: Extended;
begin
  n := Power(10, d);
  x := x * n;
  Result := (Int(x) + Int(Frac(x) * 2)) / n;
end;

initialization
  frRegisterFunctionLibrary(TReportFunctionLibrary);

finalization
  frUnRegisterFunctionLibrary(TReportFunctionLibrary);
end.

Segundo en tiempo de ejecucion no en desarrollo (al momento de dar click para ver el informe activamos el disenador frReport1.DesignReport; utilizamos la funcion que le hemos puesto mis funciones , la usamos asi

Cust:=roundd([([roundd([Sum([Imp_partes."TOTAL_LINEA"])],2)]*12/100)],2);

y listo , ya podremos declarar las funciones que queramos gracias a su apoyo
__________________
IVAND
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
El round no funciona como debe ser ? IVAND SQL 1 30-07-2007 21:21:13
Función Que No Me Funciona En Una Dll MON___ OOP 3 21-04-2007 02:20:25
Problema con round() CFPA86 Varios 1 21-02-2007 20:37:37
Funcion para saber si un registro .dbf esta bloqueado ( en red no me funciona ) Wonni Conexión con bases de datos 7 06-10-2006 19:49:32
¿Cómo funciona la función sum en SQL? nuri SQL 9 11-08-2005 17:12:25


La franja horaria es GMT +2. Ahora son las 21:40:42.


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