|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
|||
|
|||
Доработать, исправить код
задача такая, среда Delphi7-Имеется Memo с некими строками типа :
болт=1 //(болт-название, 1- количество) машина=4 булка=3 пустая строка и имеется текстовый файл пустой! или со строками типа: 12.12.2018 компот=2 болт=1 машина =1 пустая строка Задание: нужно пройтись по Мемо по всем строкам , найти в файле совпадения типа болт=болт и сложить их количество и перезаписать исходный файл с новыми значениями количества, если в файле нет совпадения типа "Болт"="Болт"" . то просто добавить в файл такую строку В этом примере в файле должны быть записаны получившиеся строки 12.12.2018 болт=2 машина=5 булка=3 компот=2 Оплата: 1. Вы мне присылаете на почту exe-шник, я проверяю работоспособность кода 2. Если меня все устраивает в коде, отправляю вам деньги-вы мне исходный код Кусок кода я вам предоставляю, вы его исправляете, дополняете и т.д. Базы данных не предлагать и прочие хеш таблицы, только Мемо и текстовый файл (такие условия) со мной связаться если после 17-00 в аське 699297384 или днем на мыло val-tal35@mail.ru |
#2
|
|||
|
|||
Обычный TStringList или простой самописный массив решат твою задачу.
Алгоритм примерно такой (кстати, собственно тут тебе нужен map/hashmap): 1. Читаем файл, разбираем все строки и запоминаем (в TStringList или в массиве, как удобнее) пары имя=значение. 2. Так же разбираем строки из Memo, только всесто запоминания добавляем в существующие или новые. 3. Сохраняем из массива все обратно в файл с простановкой новой даты. |
#3
|
|||
|
|||
Аот весь код для твоей задачи:
Код:
type TMyData = record Name : String; QT : Integer; end; procedure ProcessData(AFileName : String; AMemo : TMemo); var A : Array of TMyData; SL : TStringList; I : Integer; sName, sQT : String; function FindItem(AName : String) : Integer; var K : Integer; begin Result := -1; For K := Low(A) To High(A) Do If AName = A[K].Name Then Begin Result := K; Break; End; If Result = -1 Then Begin SetLength(A,Length(A)+1); Result := High(A); A[Result].Name := AName; A[Result].QT := 0; End; end; begin SetLength(A,0); // just in case SL := TStringList.Create; Try // Load file and process it SL.LoadFromFile(AFileName); For I := 0 To SL.Count-1 Do If Pos('=',SL[i]) > 0 Then Begin sName := Copy(SL[i],1,Pos('=',SL[i])-1); sQT := Copy(SL[i],Pos('=',SL[i])+1,Length(SL[i])-Pos('=',SL[i])); Idx := FindItem(sName); A[Idx].QT := A[Idx].QT + StrToInt(sQT); End; // Now adding data from TMemo For I := 0 To AMemo.Lines.Count-1 Do If Pos('=',AMemo.Lines[i]) > 0 Then Begin sName := Copy(AMemo.Lines[i],1,Pos('=',AMemo.Lines[i])-1); sQT := Copy(AMemo.Lines[i],Pos('=',AMemo.Lines[i])+1,Length(AMemo.Lines[i])-Pos('=',AMemo.Lines[i])); Idx := FindItem(sName); A[Idx].QT := A[Idx].QT + StrToInt(sQT); End; // And finally save the result into the same file SL.Clear; SL.Add(DateToStr(Date)); For I ;= Low(A) To High(A) Do SL.Add(Format(%s=%d,[A[i].Name,A[i].QT]); SL.Add(''); // adding empty string at the end of list SL.SaveToFile(AFileName); Finally SetLength(A,0); // clear heap SL.Free; End; end; PS. Не проверял, могут быть маленькие очепяточки и косячки. Ну и входные данные не проверяются. |
Этот пользователь сказал Спасибо lmikle за это полезное сообщение: | ||
val-tal (22.11.2018)
|
#4
|
|||
|
|||
Не знаю уместно ли здесь выложить свой код, рискну.Прошу сильно ногами не пинать, не кодил уж лет цать, все забыл напрочь. В коментах в коде описал свой затык, помогите разобраться, ткните носом в ошибки
Код:
procedure TForm1.Button1Click(Sender: TObject); var List_prod: TStrings; i,i_f:Integer; kol_f,s_text,str,str_f,str2,str_kol:string; begin List_prod :=TStringList.Create; for i:=0 to Memo1.Lines.Count-1 do begin str:=Copy(Memo1.Lines.Strings[i], 1, Pos(' ' ,Memo1.Lines.Strings[i])-1); //до разделителя str2:=Copy(Memo1.Lines.Strings[i], Pos(' ',Memo1.Lines.Strings[i])+1,Length(Memo1.Lines.Strings[i])); //после разделителя Delete(str2, Pos('=',str2),MaxInt); str_kol:=Copy(str2, Pos('*',str2)+1,Length(str2)); //////// List_prod.LoadFromFile('prodano.txt'); for i_f := 0 to List_prod.Count - 1 do begin s_text:=Copy(List_prod.Strings[i_f], 1, Pos('=' ,List_prod.Strings[i_f])-1); str_f:=Copy(s_text, 1, Pos('=' ,s_text)-1); kol_f:=Copy(List_prod.Strings[i_f], Pos('=',List_prod.Strings[i_f])+1,Length(List_prod.Strings[i_f])); // вот здесь if проверка не правильная, не знаю как реализовать поиск слова целиком, а так ищет любую букву // допустим str= булка, условие выполнистся если даже если str=улк if (Pos(str, List_prod.Strings[i_f]) > 0) then // если в условии еще пытаюсь проверить длину str_f и str то нифига не работает-ошибка //if (Pos(str, List_prod.Strings[i_f]) > 0) and (Length(str_f)=Length(str)) then begin //showmessage('слово найдено в файле'); List_prod.Delete(i_f); List_prod.Insert(i_f, s_text+'='+FloatToStr(StrToFloat(str_kol)+StrToFloat(kol_f))); //сохраняем лист в файл и выходим из цикла List_prod.SaveToFile('prodano.txt'); Break; end; //Если слово не найдено в файле if Pos(str, List_prod.Strings[i_f]) = 0 then begin //showmessage('слова нет'); List_prod.Add(str+'='+str_kol); List_prod.SaveToFile('prodano.txt'); Break; end; List_prod.Free; ///////// end; end; end; end. |
#5
|
|||
|
|||
А в дебаггере встать на if и посмотреть значения переменных религия не позволяет?
Не совсем понял, что этот код делает. Вроде все тоже свмое, что и я тебе написал, только перелопачивает файл на каждую строчку мемо, что не есть гут. Чем тебя временный массив не устроил??? Ну и что-то еще ты в задании не досказал (судя по дополнительным обрезаниям строк в твоем коде). |
#6
|
|||
|
|||
Цитата:
|
#7
|
|||
|
|||
Во первых, до 50 строк - фигня.
Во вторых, как раз и имеет смысл закешировать данные файла, что бы не перелопачивать его каждый раз. |