AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Länge eines "Variant array of variant" (?) bestimmen [OLE]
Thema durchsuchen
Ansicht
Themen-Optionen

Länge eines "Variant array of variant" (?) bestimmen [OLE]

Ein Thema von freejay · begonnen am 24. Nov 2008 · letzter Beitrag vom 24. Nov 2008
Antwort Antwort
freejay

Registriert seit: 26. Mai 2004
Ort: Nürnberg
272 Beiträge
 
Delphi 11 Alexandria
 
#1

Länge eines "Variant array of variant" (?) bestimm

  Alt 24. Nov 2008, 17:09
Hallo zusammen,

ich habe das Problem, dass ich nicht die leiseste Ahnung habe, wie ich die Anzahl der von LinkSources* zurückgegebenen Einträge in der Variante vLinks ermitteln soll:

Delphi-Quellcode:
procedure TfMain.UpdateLinks(FileName: TFileName);
var
  vExcel: Variant;
  vWorkbook: Variant;
  vWorksheet: Variant;
  vLinks: Variant;
  i: Integer;
begin
  vExcel := CreateOleObject('excel.application');

  vWorkbook := vExcel.WorkBooks.Open(FileName,0);
  vLinks := vWorkbook.LinkSources(1);

  for i := 1 to High(vLinks) do
    ShowMessage(vLinks[i]);

  vWorkbook.Close(SaveChanges:=false);

  vExcel.Quit;
  vExcel := UnAssigned;
end;
In VBA macht man das mit UBound(vLinks), aber UBound gibt's ja in Delphi nicht - oder?

High(vLinks) geht definitiv nicht in Delphi,
vLinks.Count auch nicht.
ich habe auch versucht, das Ganze zu casten:

Delphi-Quellcode:
procedure TfMain.UpdateLinks(FileName: TFileName);
type
  TMyArrayOfVariant = array of variant;
var
...
  myLinks: TMyArrayOfVariant;
begin
...
 myLinks := TMyArrayOfVariant(vLinks);
...
end;
funktioniert auch nicht...

Hat irgendjemand eine Idee?

Danke schon jetzt!

Freejay

*LinkSources liefert die in einem Excel-Sheet verknüpften Dateien zurück.
  Mit Zitat antworten Zitat
Benutzerbild von nicodex
nicodex

Registriert seit: 2. Jan 2008
Ort: Darmstadt
286 Beiträge
 
Delphi 2007 Professional
 
#2

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 17:19
Da UBound eine Methode von/für SafeArrays zu sein scheint, tippe ich mal auf die VarArrayXxx-Funktionen (VarArrayHighBound - ruft intern OLEs 'SafeArrayGetUBound' auf ).
  Mit Zitat antworten Zitat
freejay

Registriert seit: 26. Mai 2004
Ort: Nürnberg
272 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 17:30
Super! Damit geht's! Da wär ich nie drauf gekommen...

Vielen Dank!

Gruß

Freejay
  Mit Zitat antworten Zitat
Benutzerbild von nicodex
nicodex

Registriert seit: 2. Jan 2008
Ort: Darmstadt
286 Beiträge
 
Delphi 2007 Professional
 
#4

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 17:33
Dafür gibt’s das Forum

Viel Erfolg.
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 20:48
Hallo freejay,

eine Anmerkung zu der Variablen deklaration. Statt Variant, sollte man bei OLE-Automatisierung besser OLEVariant einsetzen.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
freejay

Registriert seit: 26. Mai 2004
Ort: Nürnberg
272 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 21:21
Danke für den Tipp.

Gibt's da außer der Genauigkeit der Typbezeichnung einen Unterschied zu Variant?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#7

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 21:24
Variant ist variabel
Markus Kinzler
  Mit Zitat antworten Zitat
Apollonius

Registriert seit: 16. Apr 2007
2.325 Beiträge
 
Turbo Delphi für Win32
 
#8

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 21:26
Laut Hilfe kann ein OleVariant keine programmspezifischen Typen enthalten. Während beispielsweise von IDispatch abgeleitete Interfaces oder Widestrings also immer erlaubt sind, kann ein OleVariant im Gegensatz zum Variant keine Ansistrings oder andere Typen, die durch Ableitung von TCustomVariantType entstanden sind, enthalten.
Wer erweist der Welt einen Dienst und findet ein gutes Synonym für "Pointer"?
"An interface pointer is a pointer to a pointer. This pointer points to an array of pointers, each of which points to an interface function."
  Mit Zitat antworten Zitat
Benutzerbild von sirius
sirius

Registriert seit: 3. Jan 2007
Ort: Dresden
3.443 Beiträge
 
Delphi 7 Enterprise
 
#9

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 21:43
OleVariant wird einfach ein wenig anders gespeichert. OleVariant kann von jeder anderen Prograqmmiersprache benutzt werden. Variant ist delphispezifisch. Damit ergeben sich die Sachen, die Apollonius genannt hat. Bei den meisten Sachen merkt man innerhalb Delphi keinen Unterschied.
Dieser Beitrag ist für Jugendliche unter 18 Jahren nicht geeignet.
  Mit Zitat antworten Zitat
Apollonius

Registriert seit: 16. Apr 2007
2.325 Beiträge
 
Turbo Delphi für Win32
 
#10

Re: Länge eines "Variant array of variant" (?) bes

  Alt 24. Nov 2008, 21:48
Zitat von sirius:
OleVariant wird einfach ein wenig anders gespeichert.
Tatsächlich? Ich dachte, dass bei OleVariant lediglich die möglichen Werte für VType eingeschränkt sind.
Wer erweist der Welt einen Dienst und findet ein gutes Synonym für "Pointer"?
"An interface pointer is a pointer to a pointer. This pointer points to an array of pointers, each of which points to an interface function."
  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 03:44 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