Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Grupo de Teaming del ClubDelphi

 
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 31-10-2003
__cadetill __cadetill is offline
Miembro
 
Registrado: may 2003
Posts: 3.387
Poder: 25
__cadetill Va por buen camino
TStrings, DelimitedText y Delimiter

Hola compañeros

Estoy haciendo un programita que me tiene que traspasar un fichero csv (separado por ;) a una base de datos. Había pensado en aprobechar la potencia que tienen los TStrings en Delphi gracias a sus propiedades DelimitedText y Delimiter.

En principio, si se lee el fichero con readln, tengo todo un registro que hay que añadir/modificar en la tabla, separando por ; los distintos campos.

Bien, gracias a las mencionadas propiedades del TStrings, si hago lo siguiente

Código:
  L := TStringList.Create;
  L.Delimiter := ';';
  Readln(F, str);
  L.DelimitedText := str;
  FreeAndNil(L);
funciona todo correctamente (por supuesto, la lectura del fichero dentro de un bucle y con los respectivos try..finally..end).
El problema está en si un campo lleva una ",". Es decir, un ejemplo:

14345;PEPITO PALOTES, Conxi;C/;Isaac Peral;.......

Si vemos, en elsegundo campo (el nombre), hay una "," que separa apellidos y nombre. Pues bien, si el valor de este campo está tal cual (es decir, tal como biene el fichero csv), el TStrings me lo coge como si de 2 campos se trataran (aún habiendo puesto Delimiter a ";".

Haciendo pruebas, he visto que si pongo el texto entre comillas, sí me lo coge como un sólo campo (que es el valor definido por defecto en la propiedad QuoteChar del TStrings)

14345;"PEPITO PALOTES, Conxi";C/;Isaac Peral;.......

Pero claro, si el fichero fuera algo pequeño, no hay problema, lo cambio a mano y listo, pero es que no es nada pequeño

Alguna idea?

Gracias
Responder Con Cita
 



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 11:35:06.


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