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 08-03-2008
Angel Fernández Angel Fernández is offline
Miembro
 
Registrado: may 2004
Ubicación: Valencia - España
Posts: 141
Poder: 20
Angel Fernández Va por buen camino
Procedimiento que lleva mucho tiempo y hace uso 100% de la cpu.

Hola a todos. Quisiera consultaros un problemilla que tengo.

Tengo una aplicación que recoge datos de un archivo de texto donde los datos están separados por puntos y comas (fichero .csv) y los guarda en una base de datos firebird.
Para ello utilizo un código que amablemente me ofreció Tocomi en este hilo. Esto funciona perfectamente (gracias Tocomi).
El problema es que los archivos csv son inmensos (35000 líneas con 40 columnas) y el proceso (leer datos, convertir, comprobar, guardar etc.) lleva mucho tiempo y utiliza al 100% la cpu.
Para expresarme mejor, son 2 problemas juntos:
1. Lleva mucho tiempo.
2. Durante ese tiempo usa la cpu al 100%.

Si solvento el problema 2 poniendo un sleep(500) en cada línea para que respire la cpu, el problema 1 se me agudiza, llegando a tardar cerca de 30 minutos.
Si no pongo el sleep(xx), el tiempo baja considerablemente pero el consumo de cpu es, ya digo, del 100% todo el tiempo.

¿Qué es mejor? ¿Menos tiempo con uso de 100% de la cpu o mucho más tiempo con consumo de cpu del 20%? O, quizá una solución intermedia: ¿le pregunto al usuario qué prefiere y según su contestación pongo el sleep?

Un uso del 100% de la cpu lo hacen algunos programas de cálculo muy intenso, por ejemplo lame encoder cuando convierte de wav a mp3. Esto lo pongo como ejemplo que yo conozco.

Agradecería vuestros comentarios.

Saludos al foro.
Responder Con Cita
  #2  
Antiguo 08-03-2008
Avatar de ixMike
ixMike ixMike is offline
Miembro
 
Registrado: feb 2004
Posts: 1.151
Poder: 22
ixMike Va por buen camino
No te preocupes por el 100% de uso, es normal. No recuerdo la expliación exacta, pero es algo de que el sistema tiende a aprovechar los recursos al máximo para finalizar antes los procesos.

Pero ese 100% de uso podrás comprobar que no bloquea el PC para nada.

En cuestión de agilizar el proceso, será cuestión de echarle un vistazo al código a ver qué se puede optimizar.


Salu2

Edito: he visto el código que te han dado, yo me pensaba que era todo, pero sólo es el que extrae los datos del .txt. ¿Nos puedes enseñar el código que utilizas para el proceso?

Última edición por ixMike fecha: 08-03-2008 a las 01:02:10.
Responder Con Cita
  #3  
Antiguo 08-03-2008
Neeruu Neeruu is offline
Miembro
 
Registrado: oct 2007
Posts: 485
Poder: 17
Neeruu Va por buen camino
Cool Tiempo y hace uso 100% de la CPU

Hola como estas?

te comento que tenia el mismo problema pero con archivos de texto (txt) pero con muchas mas cantidad de lineas y el procedimiento era bastante pesado tambien...

Lo mejore cambiando algunas cosas que optimizaron de forma sorprendente!!

(Aclaro que lo hice sobre interbase)

Primero:
Interbase tiene una particularidad, que podemos crear una tabla a partir de un archivo enterno, por ejemplo el txt

Por supuesto que tiene que tener ciertas caracteristicas este archivo, pero ya no es lo mismo aplicarlo sobre el archivo de texto que sobre una tabla!!!

Segundo:
En las tablas que son afectadas por el procedimeinto creo indices! y en el procedimiento todas las relaciones y consultas las hago tratando de utilizar esos indices!

La caracteristicas que tiene que tener el archivo para que interbase te lo reconosca, te lo paso mañana...No estoy en casa ahora....

Espero que te sirva..

Atte Saluda Neeruu
Responder Con Cita
  #4  
Antiguo 08-03-2008
Angel Fernández Angel Fernández is offline
Miembro
 
Registrado: may 2004
Ubicación: Valencia - España
Posts: 141
Poder: 20
Angel Fernández Va por buen camino
Gracias por vuestras rápidas respuestas.

Neeruu, te tomo la palabra, si puedes, pásame las características que debe tener el archivo csv.

Un saludo.
Responder Con Cita
  #5  
Antiguo 10-03-2008
Neeruu Neeruu is offline
Miembro
 
Registrado: oct 2007
Posts: 485
Poder: 17
Neeruu Va por buen camino
Cool Procedimiento que lleva mucho tiempo y ...

hola aca pongo el codigo prometido

CREATE TABLE TABLAEXTERNA EXTERNAL 'C:\TABLAEXTERNA.TXT' (
CAMPO1 CHAR(4),
CAMPO2 CHAR(4),
CAMPO3 CHAR(4),
CR CHAR(2)
)

este archivo lo pones en la carpeta ext que esta adentro de la carpeta de intalacion de interbase!!!!


Otra cosa que estuve pensando es porque no te creas una tabla auxiliar con los campos de cvs y luego exportas los datos a esa tabla, y asi operas con esa tabla aux en ves de con el archivo plano...

P/D: Mira aca o busca como crear tablas externas
http://www.clubdelphi.com/foros/arch...p/t-20975.html
Atte Saluda Neeruu

Última edición por Neeruu fecha: 10-03-2008 a las 18:08:50. Razón: Agreo P/D
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
Signos de que pasas mucho tiempo en Delphi o programando ContraVeneno La Taberna 28 20-02-2008 21:39:27
Crear procedimiento almacenado en tiempo real ElCherchu Firebird e Interbase 2 26-03-2007 19:30:13
Como se hace un Procedimiento en Interbase juliopag1 Conexión con bases de datos 1 02-06-2005 16:51:29
Me lleva el diablo.... sercornejov Firebird e Interbase 5 13-12-2004 23:39:45
Last no me lleva al ultimo marcelofabiani Firebird e Interbase 4 18-07-2003 20:10:02


La franja horaria es GMT +2. Ahora son las 02:49:18.


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