Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Закрытая тема
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 21.10.2013, 16:27
bloodmaster89 bloodmaster89 вне форума
Прохожий
 
Регистрация: 29.09.2013
Сообщения: 16
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Сравнение двух текстовых файлов

Здравствуйте уважаемые форумчане!
Подскажите как можно сравнить два текстовых файлов на наличие повторений.
Допустим в одном файле 1.txt записано:
3 1
4 1
2 2
3 2
4 2
5 2
6 2
1 3
2 3
3 3
4 3
5 3
6 3
1 4
2 4
3 4
4 4
В текстовом файле 2.txt записано:
2 1
3 1
1 2
4 3
2 4
3 4
4 4
5 5
6 5
В текстовом файле 1.txt необходимо убрать строки,которые совпадают со строками в 2.txt.
Заранее благодарен за ответ!
  #2  
Старый 21.10.2013, 17:45
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Немного G-кода
Код:
procedure TForm1.Button1Click(Sender: TObject);
var
 i, j: integer;
 sl1, sl2, sl3: TStrings;
 flg: boolean;
begin
 sl1:= TStringList.Create;
 sl2:= TStringList.Create;
 sl3:= TStringList.Create;
 sl1.LoadFromFile('1.txt');
 sl2.LoadFromFile('2.txt');
for i := 0 to sl1.Count - 1 do
 begin
  flg:= true;
  for j := 0 to sl2.Count - 1 do
   if sl1.Strings[i] = sl2.Strings[j] then flg:= false;
  if flg then sl3.Add(sl1.Strings[i]);
 end;
sl1.Free;
sl2.Free;
sl3.SaveToFile('1.txt');
sl3.Free;
end;
Этот пользователь сказал Спасибо Alegun за это полезное сообщение:
bloodmaster89 (22.10.2013)
  #3  
Старый 21.10.2013, 18:02
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

IndexOf() вместо второго цикла можно сделать.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
  #4  
Старый 21.10.2013, 18:15
Sibay Sibay вне форума
Прохожий
 
Регистрация: 21.10.2013
Сообщения: 5
Версия Delphi: Delphi XE5
Репутация: 10
По умолчанию

Хочу добавить, что задачу по сравнению очень больших текстовых файлов решать лучше с помощью Memory Mapped Files и сравнивать файлы побайтово (если ASCII кодировка и по два байта, если Unicode). Указанный выше способ большие файлы будет сравнивать очень долго и в StringList можно загрузить только 2Gb, а если процесс 32 битный, то получаем, грубо говоря, что можно сравнить два файла суммарный размер которых не более 2Gb.
  #5  
Старый 21.10.2013, 18:36
Аватар для M.A.D.M.A.N.
M.A.D.M.A.N. M.A.D.M.A.N. вне форума
Sir Richard Abramson
 
Регистрация: 05.04.2008
Сообщения: 5,505
Версия Delphi: XE10
Репутация: выкл
По умолчанию

Ну раз пошла такая пьянка, то можно использовать мэппинг файлы.
__________________
— Как тебя понимать?
— Понимать меня не обязательно. Обязательно меня любить и кормить вовремя.


На Delphi, увы, больше не программирую.
Рекомендуемая литература по программированию
  #6  
Старый 21.10.2013, 19:44
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Цитата:
Сообщение от Sibay
...Указанный выше способ большие файлы будет сравнивать очень долго и в StringList можно загрузить только 2Gb...
2Gb в текстовом файле, оригинально. Есть другие, более подходящие для этого носители, а здесь на такие размеры нет даже намека, так что, прокатит вполне
  #7  
Старый 21.10.2013, 20:09
Sibay Sibay вне форума
Прохожий
 
Регистрация: 21.10.2013
Сообщения: 5
Версия Delphi: Delphi XE5
Репутация: 10
По умолчанию

Не ради наезда написал это, и дело не в том, что такая задача не была поставлена. Я сам не далеко ушел от новичка и в самом начале мне бы была полезна подобная информация, ею и поделился. Собственно, поэтому и написал Memory Mapped Files чтобы те, кому интересно, могли погуглить в целях общего развития.
  #8  
Старый 22.10.2013, 04:43
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,088
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от Sibay
Не ради наезда написал это, и дело не в том, что такая задача не была поставлена. Я сам не далеко ушел от новичка и в самом начале мне бы была полезна подобная информация, ею и поделился. Собственно, поэтому и написал Memory Mapped Files чтобы те, кому интересно, могли погуглить в целях общего развития.

Не сильно поможет. Все равно надо будет один из них загрузить в память. Если файлы действительно большие, то надо их отсортировать. Вот тогда можно обойтись малым объемом памяти. Хотя на диске все-равно будет много места занято, т.к. проидется создавать третий файл, содержащий результат.

А для маленьких файлов Alegun был на правльном пути. Вот мой вариант:
Код:
procedure TForm1.Button1Click(Sender: TObject);
var
  i : integer;
  sl1, sl2 : TStrings;
begin
  sl1:= TStringList.Create;
  sl2:= TStringList.Create;
  Try
    sl1.LoadFromFile('1.txt');
    sl2.LoadFromFile('2.txt');
    for i := sl1.Count - 1 downto 0 do
      if sl2.IndexOf(sl1[i]) >= 0 Then sl1.Delete(i);
    sl1.SaveToFile('1.txt');
  Finally
    sl1.Free;
    sl2.Free;
  End;    
end;
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
bloodmaster89 (22.10.2013)
  #9  
Старый 22.10.2013, 14:24
bloodmaster89 bloodmaster89 вне форума
Прохожий
 
Регистрация: 29.09.2013
Сообщения: 16
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Большое спасибо!

Всем спасибо за ответы! Тему можно закрыть
Закрытая тема


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 21:38.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025