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

Вниз

Помогите организовать поиск и удаление строки в Excele   Найти похожие ветки 

 
rodionov_uv   (2012-03-29 12:35) [0]

Столкнулся с проблемой поиска и удаления строки в Excele.
Суть программы имеем некий Excel файл с тремя вкладками : наименованием товара, наименованием работ и вкладка Temp куда вставляются значения из первых двух вкладок для дальнейшей распечатки.

вставляю строки так :

procedure TFormTovarchek.ButAddClick(Sender: TObject);
var sum : integer;
begin
 if (KollEdit.Text = "") or (TovarEdit.Text = "") then
 begin
   Application.MessageBox("У Вас заполнены не все поля.", "Предупреждение", MB_ICONWARNING+MB_OK);
   KollEdit.SetFocus;
   Abort;
 end;
 if TovarEdit.Text <> DBGridEh1.Fields[0].DisplayText then
 begin
   Application.MessageBox("У Вас не правильно заполнено поле ввода.", "Предупреждение", MB_ICONWARNING+MB_OK);
   TovarEdit.SetFocus;
   Abort;
 end;
 ButPrint.Enabled := True;
 ADOQuery2.Close;
 sum := StrToInt(ZenaEdit.Text)*StrToInt(KollEdit.Text);
 with ADOQuery2.Sql do
   begin
     Clear;
     Add("INSERT INTO [Temp$] (name, ed, cena, kol, itog) ");
     Add("VALUES ("""+TovarEdit.Text+""", """+EdizmEdit.Text+""", """+ZenaEdit.Text+""", """+KollEdit.Text+""", """+IntToStr(sum)+""")");
   end;
 ADOQuery2.ExecSQL;
 ADOQuery2.Close;
 KollEdit.Text := "";
 TovarEdit.Text := "";
 with ADOQuery2.SQL do
   begin
     Clear;
     Add("select *");
     Add("from [Temp$]");
   end;
 ADOQuery2.Open;
 DBGridEh2.Columns[4].Footer.Value := intToStr(SumItog);
end;


Очищаю вкладку Temp так :


procedure TFormTovarchek.ButClearClick(Sender: TObject);
var
 Excel, exSheet: Variant;
 WBk : OleVariant;
 nam: string;
begin
 nam := ExtractFilePath(Application.ExeName)+"Справочник.xls";
 ADOConnection2.Connected := False;
 ADOQuery2.Close;
 Excel := CreateOleObject("Excel.Application");
 WBk := Excel.WorkBooks.Open(nam);
 Excel.Visible := False;
 exSheet := WBk.WorkSheets[3];
 exSheet.Range["A2:T100"].Clear;
 exSheet := Unassigned;
 WBk.Close(SaveChanges := True);
 Excel.Quit;
 ADOConnection2.Connected := True;
 ADOQuery1.Open;
 ADOQuery2.Open;
 DBGridEh2.Columns[4].Footer.Value := intToStr(SumItog);
end;


пробовал искать так :


var
vFind: OleVariant;
s: String;
..............
vFind:=vFind.Find(s);
 if Pointer(IDispatch(vFind))<>nil then ShowMessage("Нашёл");
..............


выскакивает ошибка.Перепробовал все варианты из интернета везде ошибка выскакивает.

помогите плиз


 
Медвежонок Пятачок ©   (2012-03-29 12:41) [1]

не надо вставлять никаких данных в лист темп. тем более из делфи.
лист темп должен содержать формулы-ссылки на данные других листов.


 
rodionov_uv   (2012-03-29 17:44) [2]

Всё проблему решил


procedure TFormTovarchek.ButDelClick(Sender: TObject);
var
 Excel, exSheet : Variant;
 WBk : OleVariant;
 nam : string;
 i : integer;
begin
 ButDel.Enabled := False;
 nam := ExtractFilePath(Application.ExeName)+"&#209;&#239;&#240;&#224;&#226;&#238;&#247;&#237;&#232;&#234;.xls";
 i := ADOQuery2.RecNo;
 ADOConnection2.Connected := False;
 ADOQuery2.Close;
 Excel := CreateOleObject("Excel.Application");
 WBk := Excel.WorkBooks.Open(nam);
 Excel.Visible := False;
 Excel.DisplayAlerts:=False;
 exSheet := WBk.WorkSheets[3];
 exSheet.Rows[i+1].Delete;
 exSheet := Unassigned;
 WBk.Close(SaveChanges := True);
 Excel.Quit;
 ADOConnection2.Connected := True;
 ADOQuery1.Open;
 ADOQuery2.Open;
 DBGridEh2.Columns[4].Footer.Value := intToStr(SumItog);
end;



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

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

Наверх




Память: 0.48 MB
Время: 0.186 c
15-1330201802
Юрий
2012-02-26 00:30
2013.03.22
С днем рождения ! 26 февраля 2012 воскресенье


15-1343759274
Rouse_
2012-07-31 22:27
2013.03.22
Кто сидит на корбине, нид хелп небольшой


11-1244731932
Dy1
2009-06-11 18:52
2013.03.22
БД


15-1347085902
Опять я
2012-09-08 10:31
2013.03.22
H.264


15-1333270898
xayam
2012-04-01 13:01
2013.03.22
Ищу устройство