Приветствую Вас Гость | RSS

Меню сайта

Реклама

Категории раздела
ADO [17]
ASCII и CSV [12]
Access [20]
Alias [24]
BDE [37]
BLOB поля [19]
Clipper [2]
DB2 [2]
DBASE и DBF [26]
Fox Pro [1]
Interbase [21]
MSSQL [0]
ODBC [10]
Oracle [0]
Paradox [0]
SQL [29]
Sybase [1]
База данных [0]
Закладки [2]
Записи [0]
Индексы [10]
Компоненты и Базы данных [0]
Модуль данных [3]
Отчеты [2]
Ошибки БД [17]
Поиск [16]
Поля [0]
Сортировка и Фильтр [6]
Таблицы [0]

Наш опрос
Есть ли у Вас свой сайт?
Всего ответов: 48

Статистика

Онлайн всего: 4
Гостей: 4
Пользователей: 0

Форма входа

Главная » Статьи » Базы данных » ASCII и CSV

Разбивка строки на слова
Приведу несколько простых функций, позволяющих работать с отдельными словами в строке. Возможно они пригодятся вам для разбивки текстовых полей на отдельные слова (for i := 1 to NumToken do ...) с последующим сохранением их в базе данных. 



function GetToken(aString, SepChar: string; TokenNum: Byte): string;
{
параметры: aString : полная строка

SepChar : единственный символ, служащий
разделителем между словами (подстроками)
TokenNum: номер требуемого слова (подстроки))
result : искомое слово или пустая строка, если количество слов

меньше значения 'TokenNum'
}
var

  Token: string;
  StrLen: Byte;
  TNum: Byte;
  TEnd: Byte;

begin

  StrLen := Length(aString);
  TNum := 1;
  TEnd := StrLen;
  while ((TNum <= TokenNum) and (TEnd <> 0)) do
  begin
  TEnd := Pos(SepChar, aString);
  if TEnd <> 0 then
  begin
  Token := Copy(aString, 1, TEnd - 1);
  Delete(aString, 1, TEnd);
  Inc(TNum);
  end
  else
  begin
  Token := aString;
  end;
  end;
  if TNum >= TokenNum then
  begin
  GetToken1 := Token;
  end
  else
  begin
  GetToken1 := '';
  end;
end;

function NumToken(aString, SepChar: string): Byte;
{
parameters: aString : полная строка

SepChar : единственный символ, служащий
разделителем между словами (подстроками)
result : количество найденных слов (подстрок)
}

var

  RChar: Char;
  StrLen: Byte;
  TNum: Byte;
  TEnd: Byte;

begin

  if SepChar = '#' then
  begin
  RChar := '*'
  end
  else
  begin
  RChar := '#'
  end;
  StrLen := Length(aString);
  TNum := 0;
  TEnd := StrLen;
  while TEnd <> 0 do
  begin
  Inc(TNum);
  TEnd := Pos(SepChar, aString);
  if TEnd <> 0 then
  begin
  aString[TEnd] := RChar;
  end;
  end;
  Result := TNum;
end;

// Или другое решение:

function CopyColumn(const s_string: string; c_fence: char;
  i_index: integer): string;
var
  i, i_left: integer;
begin

  result := EmptyStr;
  if i_index = 0 then
  begin
  exit;
  end;
  i_left := 0;
  for i := 1 to Length(s_string) do
  begin
  if s_string[i] = c_fence then
  begin
  Dec(i_index);
  if i_index = 0 then
  begin
  result := Copy(s_string, i_left + 1, i - i_left - 1);
  exit;
  end
  else
  begin
  i_left := i;
  end;
  end;
  end;
  Dec(i_index);
  if i_index = 0 then
  begin
  result := Copy(s_string, i_left + 1, Length(s_string));
  end;
end;

 


Я знаю что в GetToken параметр SepChar (в моем случае c_fence) строка, не символ, но комментарий гласит, что функция ожидает единственный символ в этой строке, и это очевидно, поскольку если вы пошлете более одного символа, функция попросту несработает. ( Delete(aString,1,TEnd) будет ошибкой, если Length( SepChar ) > 1 ).
Категория: ASCII и CSV | Добавил: Skinner (03.07.2008)
Просмотров: 468 | Рейтинг: 0.0/0
  Delphi Lab   Главная   Регистрация   Вход  
Интересная Цитата

Поиск

Магазин


Copyright MyCorp © 2024 Хостинг от uCoz