FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
informes de contabilidad
hola amigos contarles q me encomendaron hacer un sistema de contabilidad y bueno todo iva bien ya pude generar libro diario y libro mayor
El problema q tengo es como generar Balance general donde los totales estan en la parte de la cabecera Para ser mas claros les explico como estructure mis tablas q son las siguientes: plancuentas(codigo,detalle,tipo) asientocontable(nro_asiento,fecha,tipoasiento,comprobante) detalleasiento(codigo,nro_asiento,debe,haber) Y de ahi genero libro diario,libro mayor y estado de resultados pero la verdad nose como hacer para generar balance general, un ejemplo del plan de cuentas es el sgte: codigo detalle tipo 1 activo grupo 1.1 activo disponible grupo 1.1.1 caja grupo 1.1.1.1.* caja chica detalle 1.1.1.2.* Caja M/nacional detalle Como veran para q se registre los asientos contables solo hice q se visualicen solo los q son de tipo detalle pero para el balance general se tiene q ir acumulando dependiendo cuantos niveles se tuviera por cada cuenta por ejemplo: si tengo q el total de la cuenta caja chica es 200 lo que quisiera q salga es asi: 1 Activo 350 1.1 Activo disponible 350 1.1.1 Caja 350 1.1.1.1.* Caja chica 200 1.1.1.2.* Caja M/nacional 150 La verdad nose como tendria q hacer eso pues si bien en el ejemplo q les muestro se da el caso de q hay 3 niveles puede haver otras cuentas en las que solo hay dos o mas talves esto puede ser variable Ante todo les pido sugerencias y su gran ayuda de como puedo hacer o q tengo q cambiar para q me salga el informe de la forma q les mostre Trabajo con delphi 7 firebird y qreport y muchisimas gracias por su grandiosa ayuda |
#2
|
||||
|
||||
Si no estas muy ducho con SQL, te conviene hacer un query agrupado para obtener los saldos, algo asi.
Luego recorres el Query y en un ClientDataset por cada fila del query agregas los grupos hacia arriba y los totalizas, al final adicionas las filas del query. Esto mismo lo podes hacer en SQL en un stored procedue. Te cuento que en la actualidad, los sistemas contables usan vistas para el plan de cuenta, de esta forma tenes un plan de cuentas y todas las formas de verlo y agruparlo. Salu2, |
#3
|
|||
|
|||
Saldos Contabilidad
Yo utilizo Delphi 7 y Firevird 1.5
Les digo que yo estoy realizando un proyecto similar y tengo la misma duda, si bien en el ejemplo anterior que es sencillo escalonado, puede coincidir que al ordenar y agrupar por la cuenta y recorriendo desde abajo hacia arriba siempre que la longitud de la cuenta sea igual se suman los saldos y se acumulan en una variable, cuando se encuentre una cuenta de longitud inferior se le asigna el acumulado y así por el estilo hasta que se encuentre una cuenta con longitud superior a la actual donde se reinicia el saldo e inicia un nuevo ciclo. Pues el problema real surge cuando al ordenar alfabeticamente los hijos no quedan inmediatamente en la posición inferior del padre, por ejemplo: CUENTA DESCRIPCION SALDO 1 Activo 1,500.00 11 Disponible 1,500.00 1101 Cajas 800.00 110505 Caja General 100.00 110510 Cajas menores 500.00 110515 Moneda extranjera 200.00 1110 Bancos 700.00 111005 Moneda Nacional 600.00 111010 Moneda extranjera 100.00 y así sucesivamente... En este ejemplo tienen saldo resultante de operaciones contables las cuentas de 6 dígitos, el saldo del resto se determina a partir de su saldo y el cálculo o el algoritmo se complica al determinar el 11 Disponible que es la suma de 1101 Caja y 1110 Bancos, pero que no están contínuos. Si alguien me pudiera explicar un algoritmo genérico para resolver un arbol de cualquier profundidad y complejidad le estaria muy agradecido. Ya he pensado en asignar un campo al crear cada cuenta para identificar la cuenta padre y así recorrer, pero no tengo nada que me funcione confiablemente Saludos para todos Pedro Pablo |
#4
|
||||
|
||||
Probad a hacer esto
Lo que hago es linkar la tabla detalle asiento con la parte del campo codigo que afecte, que coincide con la longitud. Saco sólo las cuentas de grupo, ya que entiendo que las de detalle no hacen falta ( and len(PC.Codigo) <= 5 ) o eso creo recordar de cuando era pequeño. Otra forma de hacerlo, es poner un campo que diga por cada cuenta que grupo de cuentas totaliza ( por ejempo, la cuenta 1 totalizará '1%', la cuenta 1.1 totalizará '1.1*' ) y a partir de ahí intentar hacer todo de una sola query o en su defecto con un campo calculado, en el que ese valor indicado sería el valor del parámetro para la segunda consulta ( ). Esta prueba la he realizado en Access, pero en cualquier motor será fácil adaptarla. Por cierto, comprobad que el cálculo está bien, no vaya a ser que acabemos como el novio de la pantoja por 'interpretar' el plan contable Suerte y un saludo
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - Última edición por fjcg02 fecha: 12-04-2007 a las 00:30:46. |
#5
|
|||
|
|||
Saldos Contabilidad
Gracias fjcg02 por tu respuesta,
Cuando la pruebe te comento
__________________
Saludos Seara2005 |
#6
|
||||
|
||||
Con lo de ordenar es tan simple como crear campos calculados como:
o algo asi... Aunque la verdad cuando he hecho esto mas bien he usado un procedimiento almacenado recursivo (o cuando fue en fox, salio sin ser recursivo...)
__________________
El malabarista. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Existe algún Proyecto de contabilidad OpenSource | socger | Varios | 2 | 27-12-2005 10:21:25 |
COMPRO Codigo Fuente Contabilidad | Anonimo | Varios | 1 | 22-05-2005 11:50:43 |
Informes en Delphi 7 | jatorve | Conexión con bases de datos | 2 | 06-03-2005 22:21:58 |
Editor de informes | CARSOFT_AR | Impresión | 4 | 24-02-2005 20:06:49 |
Problemas con los informes en XP | rvinfo | Impresión | 4 | 12-06-2003 23:55:10 |
|