Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   TStringList y Separador (https://www.clubdelphi.com/foros/showthread.php?t=93362)

mjjj 22-08-2018 23:08:21

TStringList y Separador
 
Estimados, estoy teniendo un problema para leer un archivo csv y separar por ; (punto y coma) en distintos TListbox.
El problema es que existen espacios en blanco y los considera como separador.
Adjunto código.
Favor su ayuda.

Código Delphi [-]
var
  csv :  TStringList;
  i : Integer;  
begin
    csv := TStringList.Create;

    // cargar a partir del fichero csv
    if opendialog1.Execute then
    csv.LoadFromFile(opendialog1.FileName);

    // recorrer las filas
    for i := 0 to csv.Count -1 do
    begin
    ProgressBar1.Position := i;
     listbox1.Items.Add(csv.Strings[i]);

with TStringList.Create do
begin
    QuoteChar := '  ';
    Delimiter := ';';
    DelimitedText:= csv.Strings[i];
    StrictDelimiter := true;

    // Ahora tienes separado el texto en lineas
    listbox2.Items.Add(Strings[0]);
    listbox3.Items.Add(Strings[1]);
    listbox4.Items.Add(Strings[2]);
end;
end;
end;

Casimiro Notevi 22-08-2018 23:13:53

No dices qué versión de delphi usas, y también sería conveniente ver una muestra del fichero csv.
De todas formas, echa un vistazo a este hilo.

mjjj 28-08-2018 14:48:28

Estimados, utilizo Delphi XE5, y a modo de ejemplo adjunto parte del archivo que tengo que utilizar.


Nro;Tipo Doc;Tipo Compra;RUT Proveedor;Razon Social;Folio;Fecha Docto
1;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290322;31/07/2018;31/07/2018 16:04:39;01/08/2018 14:59:03
2;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290324;31/07/2018;31/07/2018 16:07:42;01/08/2018 15:00:31
3;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290335;31/07/2018;31/07/2018 16:23:38;01/08/2018 15:00:31
4;33;Del Giro;79898540-K;TURISMO LATRACH LIMITADA;40749;30/07/2018;31/07/2018 16:23:32;01/08/2018 15:00:31
5;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290339;31/07/2018;31/07/2018 16:29:44;01/08/2018 14:59:04
...

El problema se presenta ya que considera los espacios como separadores y necesito que sean solo los punto y como (;).
Además como puedo manejar los campos fecha y hora ??
Lo que necesito hacer es insertar en una base de dato este archivo.
Espero me puedan ayudar.

ecfisa 28-08-2018 18:54:52

Hola.

¿ Probaste la sugerencia que hace gerardus (mensaje #4) en el enlace que te indicó Casimiro ? te tiene que funcionar perfectamente.

Un ejemplo con los datos de tu mensaje:
Código Delphi [-]
...
var
  s : string;
begin
  s := 'Nro;Tipo Doc;Tipo Compra;RUT Proveedor;Razon Social;Folio;Fecha Docto'+
       '1;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290322;31/07/2018;31/07/2018 16:04:39;01/08/2018 14:59:03'+
       '2;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290324;31/07/2018;31/07/2018 16:07:42;01/08/2018 15:00:31'+
       '3;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290335;31/07/2018;31/07/2018 16:23:38;01/08/2018 15:00:31'+
       '4;33;Del Giro;79898540-K;TURISMO LATRACH LIMITADA;40749;30/07/2018;31/07/2018 16:23:32;01/08/2018 15:00:31'+
       '5;33;Del Giro;76488020-K;SOLDADURAS SOLTEC SpA;290339;31/07/2018;31/07/2018 16:29:44;01/08/2018 14:59:04';
  ExtractStrings([';'], [], PChar(s), ListBox1.Items);
end;

Saludos :)

mjjj 28-08-2018 21:45:52

Me funcionó la solución presentada, pero con un problema, cuando el archivo tiene un campo "vacio" no lo considera, es decir 2 ; seguidos.
Por ejemplo...

756;61;Del Giro;76417179-9;PROVEEDOR DE COMPRA;12;24/08/2018;24/08/2018 11:11:17;;1000000;0;0;;;1000000;;;;;0;;;;0;;;;

Alguna idea ???

ecfisa 28-08-2018 22:20:23

Hola de nuevo.

Bueno, todo depende de lo que desees que aparezca cuando se encuentre un campo vacio ...

Por ejemplo si quiero que cuando encuentre un campo vacío aparezca el símbolo "~" haría:
Código Delphi [-]
...
var
  s : string;
begin
  s := '756;61;Del Giro;76417179-9;PROVEEDOR DE COMPRA;12;24/08/2018;'+
       '24/08/2018 11:11:17;;1000000;0;0;;;1000000;;;;;0;;;;0;;;;';

  s := StringReplace(s,';;',';~;', [rfReplaceAll]);

  ExtractStrings([';'], [], PChar(s), Memo1.Lines);
end;
Lo que me daría el siguiente resultado:
Cita:

756
61
Del Giro
76417179-9
PROVEEDOR DE COMPRA
12
24/08/2018
24/08/2018 11:11:17
~
1000000
0
0
~
1000000
~
~
0
~
~
0
~
~
Saludos :)


La franja horaria es GMT +2. Ahora son las 04:45:57.

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