AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Thema durchsuchen
Ansicht
Themen-Optionen

Fast Report - Leerzeile einfügen bei fehlendem Datensatz

Ein Thema von Jens Hartmann · begonnen am 3. Dez 2014 · letzter Beitrag vom 5. Dez 2014
Antwort Antwort
Seite 5 von 5   « Erste     345   
Dejan Vu
(Gast)

n/a Beiträge
 
#41

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 09:36
Wieso liest Du die Daten nicht einfach ein, kopierst sie in ein CDS, fügst Leerzeilen an den Stellen ein, die dir gefallen, und druckst das ganze vollkommen straightforward im FastReport aus? Das ist eine Sache von 5 Minuten und Du musst weder die Query noch deinen aktuellen Report anfassen...

Geändert von Dejan Vu ( 5. Dez 2014 um 10:14 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#42

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 09:38
Auf die Frage, ob es wirklich so schwer ist: Ja und Nein.

Da es noch keine Programmiersprache gibt die das DeveloperMindInterface unterstützt, muss man alles haargenau vorkauen.

Mit einer richtigen Datenbank erstellt man sich dafür eine StoredProcedure und gibt die Anlagennummer mit. Dann wird dort mit temporären Tabellen die gewünschte Struktur und Satzanzahl erstellt und zurückgeliefert. Das ist definitiv nicht schwer.

Darum als Antwort Ja und Nein
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#43

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 09:39
Wieso liest Du die Daten nicht einfach ein, kopierst sie in ein CDS, fügst Leerzeilen an den Stellen ein, die dir gefallen, und druckst das ganze vollkommen straightforward im FastReport aus? Das ist eine Sache von 5 Minuten und Du musst weder die Query noch deinen aktuellen Report anfassen?
Bitte nicht, diese Vorgehensweise (PreProcessing in der Anwendung) hatte ich schon vorgeschlagen (vor allem weil mit Access gearbeitet wird)
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider
Online

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.351 Beiträge
 
Delphi 11 Alexandria
 
#44

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 09:58
Ich habe mal schnell in Fastreport einen Report mit Lückenanzeige gemacht (siehe Anhang).
Ist auch relativ wenig Arbeit, man muss nur:

zum MasterData ein Child machen...
Die Daten ins Child...
Die Lückentexte auf MasterData
Und im MasterData PrinChildIfInvisible auf True setzen.

Code:
Var
  LetzteNummer: Integer;                                            
  AnzahlLuecken: Integer;                                            
   
procedure frxReport1OnStartReport(Sender: TfrxComponent);
begin
  LetzteNummer := 0;                                    
end;

procedure LabelLueckeOnBeforePrint(Sender: TfrxComponent);
begin
  LabelLuecke.Text := InttoStr(AnzahlLuecken) + ' fehlende Nummern';                                                      
end;

procedure MasterData1OnBeforePrint(Sender: TfrxComponent);
begin
  AnzahlLuecken := <frxDBDataset1."Nummer"> - 1 - LetzteNummer;
  LetzteNummer := <frxDBDataset1."Nummer">;                                        
  BandData.Visible := False;                                  
  if AnzahlLuecken > 0 then
    BandData.Visible := True;
end;

begin

end.
Ich verlagere zwar auch gern alles auf die Datenebene, aber das hier kann man durchaus im Report lösen.

Frank
Miniaturansicht angehängter Grafiken
fastreport.jpg  
Frank Reim
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#45

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 10:17
Bitte nicht, diese Vorgehensweise ..hatte ich schon vorgeschlagen...
Weil man Niemanden zu seinem Glück zwingen sollte? Die vorgehensweise von Dataspider ist mindestens genauso simpel, wenn man schon mal mit FR Scripten gearbeitet hat.

Na, ok. Ich halte mich raus.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#46

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 10:35
Bitte nicht, diese Vorgehensweise ..hatte ich schon vorgeschlagen...
Weil man Niemanden zu seinem Glück zwingen sollte? Die vorgehensweise von Dataspider ist mindestens genauso simpel, wenn man schon mal mit FR Scripten gearbeitet hat.
Auch dazu hatte ich mich schon ausgelassen, und die Variante von dataspider würde ich immer dann wählen, wenn ich keinen Einfluss auf die Eingangsdaten habe, ich also nur den Report bearbeiten kann. Ansonsten wähle ich da PreProcessing (Daten vor dem Report aufbereiten) und das geschieht dann entweder in der Datenbank, oder wesentlich einfacher umzusetzen (und funktioniert dann immer, egal welche Datenbank) in der Anwendung.

Das PreProcessing kann ja auch relativ einfach implementiert werden mit einem Interface
Delphi-Quellcode:
IDataSetPreProcessor = interface
  function GetDataSet : TDataSet;
  procedure SetDataSet( Value : TDataSet );
  property DataSet : TDataSet read GetDataSet write SetDataSet;
end;
Dabei sieht die einfachste Umsetzung so aus
Delphi-Quellcode:
TNullDataSetPreProcessor = class( TInterfacedObject, IDataSetPreProcessor )
private
  FDataSet : TDataSet;
  function GetDataSet : TDataSet;
  procedure SetDataSet( Value : TDataSet );
end;

function TNullDataSetPreProcessor.GetDataSet : TDataSet;
begin
  Result := FDataSet;
end;

procedure TNullDataSetPreProcessor.SetDataSet( Value : TDataSet );
begin
  FDataSet := Value;
end;
Und ein spezielles würde dann aus dem Dataset vom Setter ein ClientDataSet erzeugen und diese Zeilen dazu mogeln und über den Getter das veränderte ClientDataSet liefern.

PS
Vor ein paar Tagen/Wochen hatte ich mich schon mal zum Thema Reporting ausgelassen und angeregt dem Reporter nicht direkt mit der Datenbank zu verbinden, sondern dem Reporter eine Struktur zu übergeben, aus der der Kontext (was sind das denn für Daten) und die Daten selber (z.B. als ClientDataSet-Binary/XML) zu übergeben. Der Reporter kann dann entscheiden, mit welchen Reports das dargestellt werden kann und auch (in diesem Fall) noch die Daten vorher bearbeiten (Leerzeilen einfügen).
Ein wesentlicher Vorteil ist das Speichern dieser Informationen um Berichte reproduzierbar speichern zu können und auch um dem Benutzer bei der Berichtsgestaltung eine Beispiel-Datenmenge an die Hand zu geben, die alle Möglichkeiten der Datenmenge beinhaltet.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo ( 5. Dez 2014 um 10:48 Uhr)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#47

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 10:46
Auch dazu hatte ich mich schon ausgelassen...
Das man niemanden zu seinem Glück zwingen soll?
Zitat:
Das PreProcessing kann ja auch relativ einfach implementiert werden mit einem Interface
Da tut es dann ein kleine Methode im Datenmodul doch auch. Nicht immer ist die Verwendung eines Interfaces oder einer supererweiterbaren Klasse sinnvoll (Stichwort: gas factory, accidential complexity). Aber das ist ein anderes Thema.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#48

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 10:49
Auch dazu hatte ich mich schon ausgelassen...
Das man niemanden zu seinem Glück zwingen soll?
Zitat:
Das PreProcessing kann ja auch relativ einfach implementiert werden mit einem Interface
Da tut es dann ein kleine Methode im Datenmodul doch auch. Nicht immer ist die Verwendung eines Interfaces oder einer supererweiterbaren Klasse sinnvoll (Stichwort: gas factory, accidential complexity). Aber das ist ein anderes Thema.
Natürlich tut es das, aber irgendwie schreit hier doch einer immer bzgl. der Erweiterbarkeit herum :Morgen:
(s. mein Update vom vorherigen Beitrag)
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Benutzerbild von Jens Hartmann
Jens Hartmann

Registriert seit: 11. Jan 2009
Ort: Wilnsdorf
1.439 Beiträge
 
Delphi XE2 Professional
 
#49

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 11:22
Zitat von dataspider:

Ich habe mal schnell in Fastreport einen Report mit Lückenanzeige gemacht (siehe Anhang).
Ist auch relativ wenig Arbeit, man muss nur:

zum MasterData ein Child machen...
Die Daten ins Child...
Die Lückentexte auf MasterData
Und im MasterData PrinChildIfInvisible auf True setzen.

markieren Code:
Var
LetzteNummer: Integer;
AnzahlLuecken: Integer;

procedure frxReport1OnStartReport(Sender: TfrxComponent);
begin
LetzteNummer := 0;
end;

procedure LabelLueckeOnBeforePrint(Sender: TfrxComponent);
begin
LabelLuecke.Text := InttoStr(AnzahlLuecken) + ' fehlende Nummern';
end;

procedure MasterData1OnBeforePrint(Sender: TfrxComponent);
begin
AnzahlLuecken := <frxDBDataset1."Nummer"> - 1 - LetzteNummer;
LetzteNummer := <frxDBDataset1."Nummer">;
BandData.Visible := False;
if AnzahlLuecken > 0 then
BandData.Visible := True;
end;

begin

end.
Ich verlagere zwar auch gern alles auf die Datenebene, aber das hier kann man durchaus im Report lösen.

Frank
Das funktioniert. Und ich denke, dem Aufwand gerecht. Keine Abhängigkeit von den Anzahl der Meldergruppen und optisch genau das was ich wollte.

Danke schon mal und Gruß Jens
Miniaturansicht angehängter Grafiken
report.jpg  
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#50

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 13:07
Natürlich tut es das, aber irgendwie schreit hier doch einer immer bzgl. der Erweiterbarkeit herum
Mir wäre jetzt neu, das man in einem Forum auch schreien kann.

Sie es mal so: Eine einfache Lösung (es handelt sich hier um eine einzige kleine Methode) schließt die zukünftige Erweiterbarkeit nicht aus.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 5 von 5   « Erste     345   


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 08:58 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