| Описание |  
TStringList - полезный тип класса. Он чрезвычайно полезен для многих видов обработок списков. Элементы в строковом списке могут быть вставлены, перемещены и отсортированы. 
  
Список может быть сформирован строка за строкой, или загружен из большой строки разделенной запятой  или даже из текстового файла.
TStringList происходит от TStrings. Вы можете использовать и TStrings, но это не рекомендуется, так как он не полный - некоторые из его методов абстрактны. TStringList осуществляет эти абстрактные методы (Clear, Delete и Insert). Мы рассмотрим основные свойства и методы TStringList, включая полученные из TStrings. 
  
Свойство Count 
Возвращает число строк в списке. 
  
Свойство Capacity
  
Устанавливает или получает текущую вместимость строкового списка. Вы можете управлять этой вместимостью по необходимости.
  
Свойство Strings 
Получает или корректирует строку по данному индексу в списке (первый элемент списка имеет индекс 0). 
  
Обратите внимание, что свойство Strings является свойством, заданным по умолчанию. Это означает, что вы можете использовать его без его указания: 
  
myName := names.Strings[4]; 
  
является эквивалентным: 
  
myName := names[4]; 
  
Свойство Text 
Устанавливает или получает список в виде большой строки. Эта строка будет содержать каждую строку закончивающуюся комбинацией символов перевода каретки и перевода строки (CRLF). Полезно для загрузки из визуального объекта, который может содержать многочисленные строки текста. 
  
Свойство CommaText 
Получает или устанавливает список в виде большой строки. Эта строка будет иметь список строк разделенных запятыми. Это полезно для загрузки из экспорта текстовой электронной таблицы. Если при получении строка содержит вложенные пространства, то она будет заключена в двойные кавычки. 
  
Cвойство DelimitedText 
Получает или устанавливает список через большую строку. Эта строка содержит список строк разделенных значением Delimiter (по умолчанию - запятая). Строки, содержащие вложенные пробелы должны быть заключены в QuoteChar (по умолчанию - ").
  
Свойство QuoteChar 
Используется для замыкания строк, которые имеют вложенные пробелы при использовании DelimitedText.
  
Свойство Delimiter 
Используется для разделения строк при использовании DelimitedText .
Свойство Names 
Строки в строковом списке могут быть обработаны, как пары название/значение, как во втором примере кода. Каждая строка не должна иметь никаких внедренных пробелов, и содержать знак =. 
Это очень полезное понятие. См. свойства Value и ValueFromIndex, и метод IndexOfName.
  
Свойство Values 
Возвращает значение для данного названия, когда используются строки пары название/значение (см. выше). 
  
Свойство ValueFromIndex 
Возвращает значение по индексу строки (начинается с 0), когда используются пары название/значение. 
  
Свойство CaseSensitive 
Когда true, Delphi обрабатывает строки чувствительно к регистру при выполнении некоторых операций, таких как Sort.
  
Свойство Duplicates 
Это свойство может иметь одно из следующих перечислимых TDuplicates значений: 
  
dupIgnore Игнорирует (отбрасывает) дубликаты 
dupAccept Позволяют дубликаты 
dupError Выбрасывает исключение, если имеются дубликаты
 
  
Свойство Sorted 
Когда true, все строки будут добавляться в свою позицию отсортированной последовательности. Когда false, они будут добавляться в конец. См. также метод Sort.
  
Свойство Objects 
Возвращает объект, связанный со строкой по данному индексу, если он существует. 
  
Метод Add 
Добавляет данную строку в список, возвращая ее позицию в списке (начинается с 0). 
  
Метод Append 
Так же как и Add, но без возвращения индексного значения. 
  
Метод Insert 
Вставляет строку в заданную индексом позицию. Позиция 0 вызовет вставку в начало. 
  
Метод Delete 
Удаляет строку по данному индексу. 
  
Метод Clear 
Удаляет все строки из списка. 
  
Метод Move 
Перемещает строку из одной позиции в другую, сдвигая другие строки соответственно. 
  
Метод Exchange 
Перестанавливает две строки в списке, идентифицированные по их индексным позициям. 
  
Метод IndexOf 
Получает индекс позиции строки в списке соответствующей данной строке. Если строка не найдена, то возвращается -1. 
  
Метод IndexOfName 
Получает индекс позиция первой пары название/значение строки, где название соответствует данной строке. Если не найдена - возвращается -1. 
  
Метод Find 
То же самое, что и IndexOf, но с использованием списков сортированных строк. 
  
Метод Sort 
Если Sorted является ложным, то это вызовет сортировку списка. 
  
Метод AddStrings 
Добавляет строки из другого списка. 
  
Метод Assign 
Заменяет текущий список содержанием другого списка. 
  
Метод LoadFromFile 
Очень полезный метод,  загружает строковый список из текстового файла. Каждая текстовая строка (законченая CRLF - см. DelimitedText) становится строкой списка. 
  
Метод SaveToFile 
Сохраняет строковый список в текстовый файл.
 |  
 |  
| Похожие команды |  
AnsiString  Тип данных, который содержит строку AnsiChar
  
Array  Тип данных содержащий индексируемую коллекцию данных
  
String  Тип данных, который содержит строку символов
  
TList  Универсальный контейнер списков объектов
  
 
  |    | 
  | 
| Пример кода : Простой пример |  
 var   animals : TStringList;            // 
Определение нашей переменной списка строк 
  i       : Integer; 
begin   // Определение объекта списка 
строк, и указание нашей переменной на него 
  animals := TStringList.Create; 
   // Теперь добавляем несколько 
названия в наш список 
  animals.Add('Cat'); 
  animals.Add('Mouse'); 
  animals.Add('Giraffe'); 
   // Теперь показываем этих животных 
  for i := 0 to animals.Count-1 do     ShowMessage(animals[i]);  // animals[i] 
эквивалентно animals.Strings[i] 
end; 
 |  
Cat 
Mouse 
Giraffe 
 |  
  | 
 | | Пример кода : Использование строк название-значение |  
 var   names  : TStringList;            // 
Определение нашей переменной списка строк 
  ageStr : String; 
  i      : Integer; 
begin   // Определение объекта списка 
строк, и указание нашей переменной на него 
  names := TStringList.Create; 
   // Теперь добавляем несколько 
названия в наш список 
  names.CommaText := 'Neil=45, Brian=63, Jim=22'; 
   // И теперь находим возраст Брайена 
  ageStr := names.Values['Brian']; 
   // Показ этого значения 
  ShowMessage('Возраст Brian'а = '+ageStr); 
   // Теперь отображаем все имена и 
значение возраста 
  for i := 0 to names.Count-1 do 
  begin 
    ShowMessage(names.Names[i]+' - '+names.ValueFromIndex[i]); 
  end; 
end; 
 |  
Возраст Brian'а 63 
Neil - 45 
Brian - 63 
Jim - 22 
 |  
  | 
 | | Пример кода : Использование DelimitedText, Delimiter и QuoteChar |  
 var   cars : TStringList;            // 
Определение нашей переменной списка строк 
  i    : Integer; 
begin   // Определение объекта списка 
строк, и указание нашей переменной на него 
  cars := TStringList.Create; 
   // Теперь добавляем несколько 
значений в наш список - используя свойство DelimitedText   // 
с заменой управляющих переменных   cars.Delimiter := ' ';        // 
Каждый элемент списка будет разделён пробелом   cars.QuoteChar := '|';        // 
И каждый элемент взят в '|' 
  cars.DelimitedText := '|Honda Jazz| |Ford Mondeo| |Jaguar "E-type"|'; 
   // Теперь показываем эти автомобили 
  for i := 0 to cars.Count-1 do     ShowMessage(cars[i]);       // cars[i] 
эквивалентно cars.Strings[i] 
end; 
 |  
Honda Jazz 
Ford Mondeo 
Jaguar "E-type" 
 |  
  |