Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.03.26;
Скачать: CL | DM;

Вниз

текст (пожалуйста помогите)   Найти похожие ветки 

 
mrAndersen ©   (2006-03-06 23:03) [0]

Буду краток. Есть текстовый файл, нужно удалить
символ который стоит после символа 5 но при этом, эти действия нужно производить только с текстом в скобках.

Пример программы (программа рабочая):
procedure TForm1.Button1Click(Sender: TObject);
var
 F1,F2: TextFile;
 a: String;
 k,i,j1,j2:integer;
begin
  AssignFile(F1,"D:\old\Delphi5_s\ses1.txt");
  AssignFile(F2,"D:\old\Delphi5_s\ses2.txt");
  reset(F1);
  rewrite(F2);
begin
 While Not EOF(F1) do begin
 If Not EOLN(F1) then begin
     Readln(F1,a);
     k:=length(a);

     j1:=pos( "(" ,a);  
      j2:=pos( ")" ,a);

     for i:=j1 to j2 do

   if a[i]="5" then  Delete(a,i+1,1);
   Write(F2,a);

end;
end;
end;
CloseFile(F1);
CloseFile(F2);
end.

Есть текстовый файл - ses1.txt, в котором есть такой текст:
кактус11(156111)1561бус1(1561осень11)15611...

при компиляции выходит:
ses2.txt - текстовый файл с таким текстом:
кактус11(15111)1561бус1(1561осень11)15611...

как Вы уже заметили, есть разница, но главный вопрос состоит в том, ЧТОБЫ ТЕКСТ ИЗМЕНЯЛСЯ У ВСЕХ СКОБКАХ, А НЕ ТОЛЬКО В ПЕРВОЙ.

Буду очень признателен за любые варианты решения этой задачи.


 
ANB ©   (2006-03-07 01:28) [1]

Вместо Pos используй сканирование в цикле посимвольно всей строки.
Алгоритм будет проще, но тормознутее, если ты будешь посимвольно копировать исходную строку в целевую, а уже целевую записывать в новый файл.



Страницы: 1 вся ветка

Текущий архив: 2006.03.26;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.043 c
2-1141681419
KILROY
2006-03-07 00:43
2006.03.26
Ссылка в БД...


3-1138809212
-Вася-
2006-02-01 18:53
2006.03.26
Установка SQL Server 2000


15-1140706709
ArtemESC
2006-02-23 17:58
2006.03.26
Чем смотреть swf?


2-1142336251
zorik
2006-03-14 14:37
2006.03.26
Репликация


15-1141643051
Kaban
2006-03-06 14:04
2006.03.26
Пиксел