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 10-06-2003
Avatar de apicito
apicito apicito is offline
Miembro
 
Registrado: may 2003
Ubicación: Ourense
Posts: 341
Poder: 21
apicito Va por buen camino
Importar de Txt sin delimitadores de registro

Estoy tratando de importar a una base de Datos desde un fichero Txt en el que los registros no están delimitados( ni siquiera con retorno de carro).
Como le indico al readln que tiene que leer 720 caracteres para cada registro?
Responder Con Cita
  #2  
Antiguo 10-06-2003
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 25
__cadetill Va por buen camino
no utilices readln, utiliza read, que te lee caracter a caracter, asi solo tienes que meterlo en un bucle que te cuente los caracteres que quieras leer

espero te sirva
Responder Con Cita
  #3  
Antiguo 10-06-2003
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.932
Poder: 27
delphi.com.ar Va por buen camino
Si te interesa, te recomiendo que pruebes un componente de mi página llamado TFileReader


Saludos!
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #4  
Antiguo 11-06-2003
Avatar de apicito
apicito apicito is offline
Miembro
 
Registrado: may 2003
Ubicación: Ourense
Posts: 341
Poder: 21
apicito Va por buen camino
Cita:
Posteado originalmente por cadetill
no utilices readln, utiliza read, que te lee caracter a caracter, asi solo tienes que meterlo en un bucle que te cuente los caracteres que quieras leer
espero te sirva
¿Y en que tipo de variable puedo almacenar 720 caracteres para luego pasarlos a los campos de la base de datos?
Responder Con Cita
  #5  
Antiguo 11-06-2003
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 25
__cadetill Va por buen camino
Ahora, al hacer el readln, en que tipo de variable almacenabas los datos leidos?

De todas maneras una variable de tipo string te lo permite, sino un AnsiString

Nos leemos
Responder Con Cita
  #6  
Antiguo 13-06-2003
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
¡Buen día a todos!

Apicito:

¿Podrías mostrarnos una muestra de ese archivo de texto y la estructura de campos destino?

Agradecería una copia detallada a mi cuenta de correo electrónico.

¡Hasta luego!

Al González .
Desarrollador de componentes a la medida.
Responder Con Cita
  #7  
Antiguo 13-06-2003
Avatar de apicito
apicito apicito is offline
Miembro
 
Registrado: may 2003
Ubicación: Ourense
Posts: 341
Poder: 21
apicito Va por buen camino
Cita:

¿Podrías mostrarnos una muestra de ese archivo de texto y la estructura de campos destino?
El fichero de texto es el Padrón de Fincas Rústicas de un Ayuntamiento y tiene 140 Mb, por lo que no te lo puedo enviar.
La estructura de la tabla a donde la cargo es:

CREATE TABLE "RUSTICA2002"
(
"POLIGONO" INTEGER,
"PARCELA" INTEGER,
"UNIDFISCAL" INTEGER,
"NOME" CHAR(60),
"NIF" CHAR(10),
"NIFTIPO" CHAR(1),
"COMUNIDAD" CHAR(1),
"COMUNEROS" INTEGER,
"PORCENTAXE" DECIMAL(5, 2),
"PARAXE" CHAR(20),
"TITULO" CHAR(2),
"SUPERFICIE" INTEGER,
"VALOR" DECIMAL(10, 2),
"ALTA" CHAR(4)
);
Podrías explicarme por que te interesa este tema?
Responder Con Cita
  #8  
Antiguo 14-06-2003
Avatar de Al González
[Al González] Al González is offline
In .pas since 1991
 
Registrado: may 2003
Posts: 5.604
Poder: 29
Al González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en brutoAl González Es un diamante en bruto
Cita:
Escrito originalmente por Apicito:
...tiene que leer 720 caracteres para cada registro...
Lo que pasa es que me interesa una muestra tanto del formato origen como del formato destino, para ver si te puedo poner aquí un ejemplo de cómo hacerlo.

¿Podrías darnos una muestra de un par de esos registros de 720 caracteres para darnos una idea más clara de cómo es el formato origen?

Con respecto a tu pregunta original, creo que sería conveniente tener una variable de tipo Record con una estructura de campos igual a la de los registros a leer y luego utilizar las funciones Reset y BlockRead para leer cada registro, o mejor aún, con un objeto de clase TFileStream.

Espero esto sea de utilidad. Seguimos en contacto.

Al González .
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


La franja horaria es GMT +2. Ahora son las 07:45:15.


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