TStringList-TStrings Tutorial/es

From Free Pascal wiki
Jump to: navigation, search

Deutsch (de) English (en) español (es) suomi (fi) français (fr) русский (ru)

TStringList

   TStringList (o su padre TStrings) se parece mucho a una matriz dinámica o conjunto de cadenas (un conjunto de cadenas no es posible en FPC). ¡Será muy útil al programar y yo te voy a enseñar el uso básico de TstringList!

Comencemos con un ejemplo sencillo:

 program StrList;
 {$mode objfpc}
  uses Classes, SysUtils;
  var ListaCadenas: TStringList;
  begin
   ListaCadenas := TStringList.Create; // Esto es necesario cuando se utiliza esta clase (o en otras clases)
   ListaCadenas.Add('¡Algo de texto!');
   WriteLn('La lista de cadenas (tstringlist) contiene ' + IntToStr(ListaCadenas.Count) + ' cadena(s).');
   ReadLn;
   ListaCadenas.Free; // Libera la memoria utilizada por esta instancia StringList
 end.

   Este es un programa de consola simple que crea y agrega una cadena a una lista de cadenas. Ahora, he aquí algunas cosas que debes saber:

  • Create - Creará la lista de cadenas para modificar. Al utilizar Create hay que utilizar posteriormente Free para liberar la memoria que ocupa cuando ya no se utilice. Es importante porque aunque no hará cascar el programa si que contribuirá a dejarnos sin memoria en el sistema.
  • Count - Esta propiedad es un contador para el número de cadenas en la Lista.
  • Add - Este método nos permite añadir una cadena a la lista de cadenas. La función devolverá el índice de la cadena. Aquí es donde el contador viene muy bien.
  • Delete - Borra una cadena de la lista de cadenas. Debemos de saber que no debemos simplemente introducir la cadena, tenemos que introducir el índice de la cadena. Como he dicho: es como una matriz dinámica de lujo.
  • IndexOf - Devolverá el índice de la cadena en la lista. Si no lo encuentra, devuelve -1.
  • Clear - Borrará la lista completa

Ejemplo ampliado

   ¿Qué tal un ejemplo más jugoso, ¿eh?

 program StrList2;
  {$mode ObjFPC}
  uses Classes, SysUtils;
  var ListaCadenas: TstringList;
   Cadena: String;
   Contador: Integer;
  begin
     ListaCadenas := TstringList.Create;
     Writeln('Prueba de lista de cadenas');
     repeat
        Writeln('Introduce la cadena a añadir');
           Readln(Cadena);
           if (Cadena = 'Terminar') then Halt;  // Halt detiene inmediatamente la ejecución del programa.
            // Si observas atentamente, deducirás que esto lleva a una pérdida de memoria.
           if not (Cadena = '') then
              begin
                 Contador := ListaCadenas.Add(Cadena);
                 Writeln('¡La cadena: ' + Cadena + ' fue añadida!');
                 Writeln('El índice es: ' + IntToStr(Contador)); // El contador siempre será el índice de la última adición.
              end
           else
              begin
                 Writeln('No hay texto para añadir...');
              end;
     until (Cadena = 'Terminar');
     WriteLn ('Contiene: '+ ListaCadenas.CommanText);
     ListaCadenas.Free; // Libera la memoria asignada a ListaCadenas.
  end.

Sin embargo, para evitar posibles pérdidas de memoria, deberíamos utilizar el bloque try - finally siempre que sea posible. Pareciéndose a lo siguiente:

 
 
var
  slist: TStringList;
 
...
 
slist := TStringList.Create;
try
  ...
  // realizar cosas con stringlist  
  ...
finally
  if Assigned(slist) then
    FreeAndNil(slist);
end;
// Este otro funciona perfecto, no hay doble creación de Stringlist... cualquier comentario a edgarrod71@gmail.com
function theStringList: TStringList;
var
 J: integer;
begin
  result := TStringList.Create;
  for J:=0 to 10 do  // son 11 elementos
    result.add(intToStr(J));
end;
 
procedure Caller;
var
  SL: TStringList;
  K: integer;
begin
  SL := theStringList;
  for K:=0 to pred(SL.Count) do   // son 11 elementos
    writeln(SL[K]);
  if assigned(SL) then    // aquí se evita desperdicio de memoria
    SL.Free;
end;

Usando archivos

   Cuando se utiliza TStringList tenemos dos procedimientos de manipulación de archivos: SaveToFile y LoadFromFile.

  • SaveToFile guardará todas las cadenas en la lista en un archivo.
  • LoadFromFile abrirá el archivo y agregará los datos del archivo a la cadena de la lista de cadenas.
 program StrListFile;
 {$mode objfpc}
 uses
 Classes, SysUtils;
 var
  ListaCadenas: TStringList;
   begin
    ListaCadenas := TStringList.Create;
       try
          ListaCadenas.LoadFromFile('Algo_de_Texto_en_Archivo.txt');
          ListaCadenas.Add('Hola');
          ListaCadenas.SaveToFile('Algo_de_Texto_en_Archivo.txt');
       finally
          ListaCadenas.Free;
   end;
end.

   ¡Acabamos de abrir un archivo, hemos editado el texto y lo hemos guardado de nuevo¡

Comparación dinámica de matrices de cadenas

   TStringList es simplemente una versión orientada a objetos de una matriz de cadena dinámica. Algunos métodos son análogos:

Operación                      Matriz de cadenas TStringList
Declaración de Variable ListaCadenas: array of string; ListaCadenas: TStringList;
Inicialización constructor implícito ListaCadenas := TStringList.Create
Dimensionar SetLength(ListaCadenas, X); ListaCadenas.Size := X;
Obtener dimensión X := Length(ListaCadenas); X := ListaCadenas.Count;
Añadir elemento SetLength(ListaCadenas, Length(ListaCadenas) + 1); ListaCadenas[Length(ListaCadenas) - 1] := X; ListaCadenas.Add(X);
Borrar item for I := Index to Length(ListaCadenas) - 2 do ListaCadenas[I] := ListaCadenas[I + 1]; SetLength(ListaCadenas, Length(ListaCadenas) - 1); ListaCadenas.Delete(Index);             
Eliminar todos los items SetLength(ListaCadenas, 0); ListaCadenas.Clear;
Terminación destructor implícito ListaCadenas.Free;

   Sin embargo TStringList ofrece mucha mas funcionalidad que una simple estructura del tipo matriz dinámica.

Sigue aprendiendo

   

TStringList tiene algunas características interesantes adicionales:

  • 1. Permite ordenar las cadenas.
  • 2. Permite limitar el listado a solamente cadenas únicas (no repetidas).
  • 3. Se puede obtener el texto de las cadenas como una simple cadena utilizando la propiedad Text;
  • 4. Se puede almacenar un objeto u otro dato próximo a la cadena.

Para aprender los diferentes procedimientos, funciones y propiedades, puedes ver Documentación de TStringList

   Si sientes que podría haber dejado algo fuera, 'modificalo a voluntad!'

   ¡Espero que sea de ayuda!

Ver además: