AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Excel: Anzahl der Zeilen bis zum Seitenumbruch ermitteln
Thema durchsuchen
Ansicht
Themen-Optionen

Excel: Anzahl der Zeilen bis zum Seitenumbruch ermitteln

Ein Thema von Reinhardtinho · begonnen am 27. Sep 2007 · letzter Beitrag vom 28. Sep 2007
Antwort Antwort
Benutzerbild von Reinhardtinho
Reinhardtinho

Registriert seit: 26. Feb 2007
411 Beiträge
 
Delphi 5 Enterprise
 
#1

Excel: Anzahl der Zeilen bis zum Seitenumbruch ermitteln

  Alt 27. Sep 2007, 16:43
Hallo zusammen,

ich füge mittels der Komponente TExcelApplication (bei D5 unter Server) Daten in ein Exceldokument ein.

Ich habe verschieden große Blöcke und möchte nun feststellen, ob dafür noch genügend Zeilen frei sind (von meiner aktuellen Position [Zelle] bis zum nächsten Seitenumbruch). Diese Blöcke sollen immer zusammenhängend sein und nicht auf einer Seite beginnen und auf der nächsten fortgesetzt werden.

Mein Frage nun:

Wie ermittele ich die Anzahl der Zeilen von meiner Zellposition bis zum Seitenumbruch?



Vielen Dank und freundliche Grüße

Lorenz
Ich habe viel von meinem Geld für Alkohol, Weiber und schnelle Autos ausgegeben ... Den Rest habe ich einfach verpraßt.

George Best - 22.05.1946 - 25.11.2005 - nordirischer Fußballspieler
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Excel: Anzahl der Zeilen bis zum Seitenumbruch ermitteln

  Alt 27. Sep 2007, 19:53
Hallo Lorenz,

laut Excel VBA Reference solltest du ein von Excel automatisch eingefügtes PageBreak als row property abfragen können. Ich würde über die Zeilen iterieren bis ich das nächste PageBreak gefunden habe. Funktioniert auch bei Spalten und anderen Objekten.

Grüße vom marabu
  Mit Zitat antworten Zitat
Benutzerbild von Reinhardtinho
Reinhardtinho

Registriert seit: 26. Feb 2007
411 Beiträge
 
Delphi 5 Enterprise
 
#3

Re: Excel: Anzahl der Zeilen bis zum Seitenumbruch ermitteln

  Alt 28. Sep 2007, 11:14
Vielen Dank marabu,

ich poste hier mal meine Funktion, die die Anzahl der Zeilen bis zum Seitenumbruch zurückgibt:

Delphi-Quellcode:
  function GetFreeLines(WS : _WorkSheet; J : Integer) : Integer;
  var
    NextPB : Excel97.Range;
    CurrPos : Integer;
    CurrCount : Integer;
    k : Integer;
  begin
    CurrPos := J;
    CurrCount := WS.HPageBreaks.Count;

    // Zeilen befüllen, damit Count hochgezählt wird
    while (WS.HPageBreaks.Count = CurrCount) do
    begin
      Inc(J);
      WS.Cells.Item[J,1].Select;
      WS.Cells.Item[J,1].Value := '0';
    end; (* of while *)

    NextPB := WS.HPageBreaks.Item[WS.HPageBreaks.Count].Location;

    // Zeilen wieder leeren
    for k := j downto CurrPos do
    begin
      WS.Cells.Item[k,1].Select;
      WS.Cells.Item[k,1].Value := '';
    end; (* of for *)

    result := NextPB.Row - WS.Cells.Item[CurrPos,1].Row;
  end; (* of GetFreeLines *)
Mit J wird die aktuelle Position überbegen.

Man muss wohl was in die Zellen reinschreiben, damit der automatische Zeilenumbruch aktiv wird, mit leeren Zellen hat es bei mir nicht funktioniert.

MFG
Lorenz
Ich habe viel von meinem Geld für Alkohol, Weiber und schnelle Autos ausgegeben ... Den Rest habe ich einfach verpraßt.

George Best - 22.05.1946 - 25.11.2005 - nordirischer Fußballspieler
  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:21 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