AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Excel_TLB Probleme mit Excel2010

Ein Thema von delphigeorge · begonnen am 27. Nov 2012 · letzter Beitrag vom 6. Dez 2012
Antwort Antwort
delphigeorge

Registriert seit: 4. Apr 2007
19 Beiträge
 
#1

Excel_TLB Probleme mit Excel2010

  Alt 27. Nov 2012, 15:09
hallo zusammen,

bisher habe ich die Excel2000_TLB genutzt, so habe ich bisher Excel-Dateien geöffnet:

Delphi-Quellcode:
  
  try
    ActWbk.Disconnect;
    MSExcel.connect;
  except
    ActWbk.Disconnect;
    MSExcel.Disconnect;
    MSExcel.Quit;
    Application.ProcessMessages;
    Application.Restore;
    showMessage('Excel konnte nicht gestartet werden');
    exit;
  end;
  if not Neu then
  begin
    try
      ActWbk.ConnectTo(MSExcel.Workbooks.Open(Docu, EmptyParam, EmptyParam,
                    EmptyParam, EmptyParam, EmptyParam,
                    Ignore, EmptyParam, EmptyParam,
                    TRUE, EmptyParam, EmptyParam,
                    EmptyParam, LCID));
    except
       MSExcel.Quit;
Mit Excel2010 gibt es nun folgendes Problem:
Hat man in einer Excel-Datei Autofilter eingesetzt und die Datei mit aktivem Filter gespeichert,
dann erscheint mit dem nächsten Aufruf über obige Routine die Meldung:

Namenskonflikt

Name darf integriertem Namen nicht gleichen.
Alter Name: _FilterDatase
Neuer Name:

Es muss ein Name eingegeben werden, sonst kommt man aus der Nummer nicht mehr raus.

Hat jemand eine Ahnung wie man die Meldung umgehen kann?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.197 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: Excel_TLB Probleme mit Excel2010

  Alt 27. Nov 2012, 16:11
Hallo,

hab den gleichen Fehler aber soweit ich sehe in der Datei keinen Autofilter (bzw. weiß nicht woran ich das erkennen kann).
Kannst du hier eine Datei mit und ohne Autofilter anhängen.

Bisher habe ich viele Meldungen mit Fehlermeldung gefunden aber keine die auf mein (und vermutlich dein) Problem mit _FilterDatase funktioniert (Hab auch die vermutung das hier MS eine Bock geschossen hat).

Nochwas: Ich gehe mit Später Bindung (also ohne TLB) auf Excel "los".
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#3

AW: Excel_TLB Probleme mit Excel2010

  Alt 27. Nov 2012, 16:36
vielleicht hilft das hier weiter.
wenn ich es richtig verstanden habe, ist "_FilterDatabase" der Name für Autofilter.
Wenn Du also ein Exel-File öffnest, daß mit einem Autofilter (mit Standardnamen) gespeichert wurde, dann macht es Peng, weil zweimal der gleiche Name, daß geht überhaupt nicht.

ggf kann man über application.worksheets den filter ausschalten ohne ein activeworksheet zu bemühen?

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
delphigeorge

Registriert seit: 4. Apr 2007
19 Beiträge
 
#4

AW: Excel_TLB Probleme mit Excel2010

  Alt 27. Nov 2012, 17:06
hallo Bernd,

anbei ein Beispiel:
Im Excel-Menü auf 'Daten|Filtern' klicken um zu filtern.
Nochmals klicken um den Filter zu entfernen.
Datei mit aktivem Filter speichern und neu aufrufen.
Angehängte Dateien
Dateityp: zip Filtern.zip (5,7 KB, 14x aufgerufen)
  Mit Zitat antworten Zitat
delphigeorge

Registriert seit: 4. Apr 2007
19 Beiträge
 
#5

AW: Excel_TLB Probleme mit Excel2010

  Alt 27. Nov 2012, 17:08
hallo K-H,

das habe ich alles schon versucht, aber ohne Erfolg.
  Mit Zitat antworten Zitat
delphigeorge

Registriert seit: 4. Apr 2007
19 Beiträge
 
#6

AW: Excel_TLB Probleme mit Excel2010

  Alt 6. Dez 2012, 14:08
hallo Bernd,

ich lösche nun in der beforeclose alle Filter die '_FilterDatabase' beinhalten,
jetzt habe ich Ruhe!
Ob Excel diese internen Filter irgendwie verwendet konnte ich nicht in Erfahrung bringen.


Delphi-Quellcode:
procedure TKMHaupt.ActWbkBeforeClose(ASender: TObject; var Cancel: WordBool);
var
  sheet: TExcelWorkSheet;
  TN : Names;
  TIN: Excel2000.Name;
  LegID, nam: string;
  i, j, x : integer;
begin
  ActWbk := TExcelWorkbook(ASender);
  sheet := TExcelWorkSheet.Create(nil);
  for i := 1 to ActWbk.Sheets.Count do
  begin
    sheet.connectTo(ActWbk.Sheets[i] as _Worksheet);
    sheet.AutoFilterMode[LCID] := False;
    TN := sheet.Names;
    for x := 0 to TN.Count -1 do
    try
      TIN := TN.Item(x, EmptyParam, Emptyparam);
      nam := TIN.Name_;
      if POS('_FilterDatabase', Nam) > 0 then
      try
        TIN.Delete;
      except
      end;

    except
    end;

  end;
  Mit Zitat antworten Zitat
Antwort Antwort

 

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:03 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz