Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  96

•  TDictionary Custom Sort  3 293

•  Fast Watermark Sources  3 043

•  3D Designer  4 798

•  Sik Screen Capture  3 293

•  Patch Maker  3 513

•  Айболит (remote control)  3 610

•  ListBox Drag & Drop  2 969

•  Доска для игры Реверси  81 417

•  Графические эффекты  3 897

•  Рисование по маске  3 209

•  Перетаскивание изображений  2 593

•  Canvas Drawing  2 712

•  Рисование Луны  2 540

•  Поворот изображения  2 146

•  Рисование стержней  2 150

•  Paint on Shape  1 556

•  Генератор кроссвордов  2 213

•  Головоломка Paletto  1 754

•  Теорема Монжа об окружностях  2 193

•  Пазл Numbrix  1 675

•  Заборы и коммивояжеры  2 046

•  Игра HIP  1 270

•  Игра Go (Го)  1 219

•  Симулятор лифта  1 463

•  Программа укладки плитки  1 204

•  Генератор лабиринта  1 534

•  Проверка числового ввода  1 340

•  HEX View  1 481

•  Физический маятник  1 347

 
скрыть


Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Импорт больших файлов с разделителями



Вот две функции, которые я использую почти во всех моих проектах. Пользоваться ею очень просто, например:


var
  s: string;
  f: TextFile;
  AssignFile(f, 'D:\INPUT.TXT');
  Reset(f);
  while not EOF(f) do

  begin
    ReadLn(s, f);
    ShowMessage(GetField(s, 1)); {Первое поле}
    ShowMessage(GetField(s, 6)); {Шестое поле}
    ShowMessage(GetField(s, 25)); {возвратит '', если нет 25 колонки...}
  end;
  CloseFile(f);

  { ==== Данная функция возвращает поле из строки с разделителем. ==== }

function GetField(InpString: string; fieldpos: Integer): string;
var

  c: Char;
  curpos, i: Integer;
begin

  curpos := 1;
  for i := 1 to fieldpos do
  begin
    result := '';
    if curpos > Length(InpString) then
      Break;
    repeat
      c := InpString[curpos];
      Inc(curpos, 1);
      if (c = '"') or (c = #13) or (c = #10) then
        c := ' ';
      if c <> ',' then
        result := result + c;
    until (c = ',') or (curpos > Length(InpString))
  end;
  if (curpos > Length(InpString)) and (i < fieldpos) then
    result := '';
  result := Trim(result);
end;

{ ==== Данная функция удаляет у строки левые и правые пробелы. ==== }

function Trim(inp_str: string): string;
var

  i: Integer;
begin

  for i := 1 to Length(inp_str) do
    if inp_str[i] <> ' ' then
      Break;
  if i > 1 then
    Delete(inp_str, 1, i - 1);
  for i := Length(inp_str) downto 1 do
    if inp_str[i] <> ' ' then
      Break;
  if i < Length(inp_str) then
    Delete(inp_str, i + 1, Length(inp_str));
  result := inp_str;
  if result = ' ' then
    result := '';
end;





Похожие по теме исходники

Чтение PSD файлов

Шифратор файлов

Поиск файлов

FileMan (менеджер файлов)

 

Поиск открытых файлов




Copyright © 2004-2024 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте