Liste mit Lücken mittels Filter aggregieren

PaulGustav

Mitglied
Hallo zusammen.

Ich bin seit einigen Monaten neu in der Java-Welt und stehe vor einem verzwickten Problem, wofür ich gerne einige Ratschläge sammeln würde:

Ich habe eine Liste, welche mittels Zeitstempel (Tag-Monat-Jahr-Stunde-Minute-Sekunde) die Belastungen von Straßen differenziert ausgibt. Diese Listen sehen wie folgt aus:
Listenkopf:
Tag/Zeit, Straße,AnzFahrzeuge,AnzRadfahrer
Listeneinträge:
01-01-2000-12-00-00, Dorfstraße, 10,0
, Schulweg, 5, 1
, Dorstraße, 12, 2
01-01-2000-12-10-00, Dorfstraße, 22, 5
, Schulweg, 10, 3
, Dorfstraße, 27, 3
, Schulweg, 7, 2
usw....

Nun möchte ich erreichen, dass ich mittels Java eine Liste/ ein Set erstelle, welche mir schließlich die Belastungen der einzelnen Straßen zu den einzelnen Zeiten bzw. Tagen zusammenfasst. Quasi in der folgenden Form:
01-01-2000-12-00-00, Dorfstraße, 22,2
01-01-2000-12-00-00, Schulweg, 5, 1
[die Leerzeile dient lediglich der Übersicht]
01-01-2000-12-10-00, Dorfstraße, 49, 8
01-01-2000-12-10-00, Schulweg, 17, 5

Für diese Problematik habe ich mich nun einige Tage mit Listen, Sets und Maps beschäftigt und frage mich nun, ob ich mit meiner Collection einer ArrayList auf dem richtigen Weg bin. Schließlich müss beim Auslesen der "Grunddaten" ja immer die einzelnen Straßenbelastungen festgehalten und infolgedessen aufsummiert werden.

Folglich habe ich dazu den folgende Codes verwendet:
Java:
//Pakete
import java.util.ArrayList;
import java.util.Collection;
import java.io.BufferedReader;

// Klasse für die Grunddaten
public class Files
{
String timeStamp, road;
int vehicles, bikes;
    // hier folgen einige Methoden sowie Konstruktoren
public Files(String timeStamp, String road, int vehicles, int bikes)
{...}
}

//Klasse zum Erstellen der Listen aus einer CSV

public class CreateLists
{
Collection<Files> list = new ArrayList<Files>();
Collection<Files> aggList = new ArrayList<Files>();

BufferedReader br = null;
String line = "";
String cvsSplitBy = ",";
String[] content = line.split(cvsSplitBy);
    // Auslesen der CSV
try{   
while ((line = br.readLine()) != null) {
// Hinzufügen der Listeneinträge in die Liste
// 0=timeStamp, 1=road, 2=vehicles, 3=bikes
list.add(new Files(content[0],content[1],content[2],content[3]));
}
// Es folgen noch Methoden zum Schreiben einer neuen CSV aus der Liste mittels einer For-Schleife
}
catch(FileNotFoundException e)
{
e.printStackTrace();
}
catch (IOException e)
{
e.printStackTrace();
}
finally
{
if (br != null)
{
try
{
br.close();
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
}

Ich habe absichtlich einiges ausgelassen um das Skript einigermaßen Minimal zu lassen.
Ich habe nun schon einige Überlegungen angestellt, innerhalb der While-Schleife die Daten so auszulesen, dass
- jeder Zeitstempel, also jede nichtleere Zelle (content[0]), einen Zähler bekommt und dass
- die Straßenbelastungen entsprechend als integer übersetzt und summiert werden.

Gerne würde ich die Lücken der Zeitstempel vorerst entsprechend füllen und dann die Inhalte einer jeden Zeile entsprechend aggregieren. Ist dies so einfach mit der Collection <ArrayList> möglich oder muss ich dabei auf Sets übergehen, um die vielen Filter bzw wenn-dann-Bedinungen zu erfüllen?

Über Anregungen und mögliche Verweise würde ich mich sehr freuen.
 

Thallius

Top Contributor
Du musst das etwas anders aufbauen. Deine Files Klasse (Der Name ist übrigens Mist) muss einen Timestamp haben und eine ArrayList<Street> wobei Street dann wieder ein Klasse ist welche aus Strassenname und Anzahlen der Fahrzeuge und Radfahrer besteht.

Wenn Du dann eine neue Zeile liest und DANACH splittest (in deinem Beispiel splittest du einen leeren String vor der while Schleife) dann suchst du in deiner ArrayList<Files> zunächst nach einem Eintrag mit dem passenden Timestamp. Findest du keinen, erzeugst du eine neue Klasse File und hängst sie an die Liste. Findest du einen, dann schaust du in der ArrayList<Street> ob es schon eine solche Strasse gibt. Wenn ja, dann addierst du die neuen Werte, wenn nein, dann erzeugst du eine neue Strasse und hängst sie an die Liste.

Gruß

Claus
 

Robat

Top Contributor
Hier einen kleine Anregung , was ich machen würde:

Du durchläufst deine liste und suchst nach einem gleichen Parameter (in deinem Fall sicherlich der Straßenname?). Elemente die deine Bedingung erfüllen kannst du in eine temporäre Liste stecken die du dann auch durchlaufst, deine Elemente zusammen addierst und es dann als neues Element in deine aggList speichern kannst

Gruß
Robert
 

PaulGustav

Mitglied
Vielen Dank für die schnellen Rückmeldungen. Habe mich gleich ans Werk gemacht.
Für die Auflistung aller Straßen habe ich nun ein HashSet, was sich alle Namen merkt und diese auch nicht doppelt aufnimmt.

@claus: Kann ich mir das so vorstellen, dass die Files-Klasse nicht wie gehabt die vier Strings (0=timeStamp, 1=road, 2=vehicles, 3=bikes) enthält, sondern nur noch den Timestamp? Dieser bräuchte dann ja auch wieder den Bezug zu der Straße und deren jeweiligen Belastungen. Quasi eine Art TreeMap nur mit mehreren Werten, was nach meiner Recherche so nicht möglich ist.

Der (leere) Split vor der While-Schleife war Murks. Er liegt nun direkt hinter der Schleife.

@Robert: Dein Ansatz hatte ich auch schon irgendwie im Sinn. Da es sich jedoch um einen Datensatz handelt, der ein ganzes Jahr mit allen Tagen und allen möglichen Zeitscheiben beinhaltet, würde ich die Zwischenspeicherung in Listen gerne bevorzugen. Ich denke, dass spart letztendlich Zeit und kann auch anhand der Listen nachvollzogen und ggf geändert werden. Oder denke ich da zu kompliziert?
Vielen Dank trotzdem
 

Thallius

Top Contributor
Paul du solltest dir im klaren werden wonach du deine Daten am Ende Zusammen fassen willst. Willst du alle Daten eines Tages mit den verschiedenen Strassen oder willst du alle Strassen mit den verschiedenen Daten?

Je nachdem musst du halt deine Klassen definieren. Es bringt ja nichts ein Set von Strassen zu machen nur damit keine Strasse doppelt vokommt. Was für eine Redundanz.

Also wenn du später eine Liste mit Daten haben willst in denen jeweils die Strassen mit Anzahlen sind dann sähen Deine Klassen so aus:

Code:
public class StreetUsageDate
{
    LocalDateTime dateTime;
    ArrayList<Street> streetList = new ArrayList<Street>;
}

public class Street
{
    String name;
    int carCount, bicecleCount;
}

Gruß

Claus
 

PaulGustav

Mitglied
Ja es soll immer ein Zeitstempel geschrieben werden, der die Straße mit ihren aggregierten Werten wiedergibt.
timestamp --> street(totalVehicles, totalBicycle)
 

mrBrown

Super-Moderator
Mitarbeiter
Das klingt sehr nach Maps...
Je nachdem wie man's lieber hat Map<LocalDate,StreetUsageData> oder Map<LocalDate,Map<Street,UsageData>, das sollte mit Java 8 recht leicht zusammenzufassen sein...
 

PaulGustav

Mitglied
Ich danke euch recht herzlich für die guten Tipps.
Ein Freund meinte ebenso, dass ich die Sache gut mit mehreren Maps lösen könnte. Habe es dann genauso gelöst wie es auch mrBrown empfohlen hat.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Liste in Variable speichern Java Basics - Anfänger-Themen 6
R Liste und Arrays Java Basics - Anfänger-Themen 12
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
M Verkettete Liste Java Basics - Anfänger-Themen 1
M Vergleichen, ob eine Liste länger als andere ist Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
E Elemente aus Liste entfernen und hinzufügen Java Basics - Anfänger-Themen 3
M Nullpointer beim befüllen meiner Liste im Object Java Basics - Anfänger-Themen 3
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
B Objekt aus generalisierter Liste entfernen Java Basics - Anfänger-Themen 11
H Liste Knoten NullPointerException Java Basics - Anfänger-Themen 7
W Liste mit Listen in JTable darstellen Java Basics - Anfänger-Themen 1
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
L Hilfe! Liste mit Items werden ausgegeben aber nicht in zufälliger Reihenfolge Java Basics - Anfänger-Themen 6
berserkerdq2 Warum soll ich shuffle nutzen, um bei Rückgabewert Collection eine Liste zurückzugeben? Java Basics - Anfänger-Themen 3
sserio Wieso werden nicht alle Primzahlen bis 1000 in meine Liste gepackt ? Java Basics - Anfänger-Themen 8
sserio Liste erstellt und ein Problem mit dem Index Java Basics - Anfänger-Themen 8
f3mys Objektwerte in Liste speichern und wieder abrufen Java Basics - Anfänger-Themen 23
H Java verkettete Liste, Wert eines Index zurückgeben Java Basics - Anfänger-Themen 1
K Warum ist die binäre Suche bei der verketteten Liste nicht so effektiv? Java Basics - Anfänger-Themen 3
I 2D-Array Position der Liste ausgeben. Java Basics - Anfänger-Themen 2
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
Igig1 Autoparkplatz verkettete Liste erstes und letztes Auto Java Basics - Anfänger-Themen 13
thor_norsk Verkette Liste Java Basics - Anfänger-Themen 27
R Rückgabe: verkettete Liste Java Basics - Anfänger-Themen 2
R einfach verkettete Liste Java Basics - Anfänger-Themen 1
R einfach verkettete Liste Java Basics - Anfänger-Themen 12
O Doppelt verkette Liste Element löschen Java Basics - Anfänger-Themen 15
B GUI extension mit einer Liste verbinden Java Basics - Anfänger-Themen 1
B Verkettete Liste durchgehen und einzelne Elemente in neue Liste tun Java Basics - Anfänger-Themen 9
B Bin komplett am verzweifeln :( Verkettete Liste die Objekte hat Attribut auslesen Java Basics - Anfänger-Themen 14
M Java Liste streamen Java Basics - Anfänger-Themen 10
AmsananKING Aussortierung einer Liste Java Basics - Anfänger-Themen 8
A Objekte mit Parametern in eine Liste packen Java Basics - Anfänger-Themen 19
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
S Kann nicht auf die Liste zugreifen mit der Methode!? Java Basics - Anfänger-Themen 3
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
alice98 Erste Schritte Liste erstellen ohne vorgefertigte Klassen Java Basics - Anfänger-Themen 1
J Doppelt verkette Liste ich bitte um Hilfe Java Basics - Anfänger-Themen 4
I Liste gruppieren nach Monat? Java Basics - Anfänger-Themen 5
districon Element in Liste einfügen Java Basics - Anfänger-Themen 1
B Hilfe bei Map Liste erstellen Java Basics - Anfänger-Themen 10
Y Einfügen in eine doppelt verkettete Liste Java Basics - Anfänger-Themen 8
Y Knoten an einem gegebenen Index aus einer Liste entfernen. Java Basics - Anfänger-Themen 6
H Daten aus einer Datei in eine Liste speichern Java Basics - Anfänger-Themen 23
Gaudimagspam Linked Liste Java Basics - Anfänger-Themen 4
Z Liste umkehren Java Basics - Anfänger-Themen 1
S Eine Liste kopieren Java Basics - Anfänger-Themen 13
java3690 Java- liste füllen ud die werte addieren Java Basics - Anfänger-Themen 13
java3690 Liste mit zufälligen zahlen füllen Java Basics - Anfänger-Themen 27
java3690 eine liste sortieren Java Basics - Anfänger-Themen 12
J Element aus Liste nehmen Java Basics - Anfänger-Themen 3
B JUnit 4: Wie man die eigene Liste testen kann [TDD] Java Basics - Anfänger-Themen 46
B Interface List - Objekt übergeben? Einzelnes Objekt geht, aber Liste nicht? Java Basics - Anfänger-Themen 4
P Was genau bringt mir es ein Array in eine Liste zu bringen Java Basics - Anfänger-Themen 3
A Doppelt verkettete Liste rückwärts ausgeben Java Basics - Anfänger-Themen 17
P Verschachtelte Array Liste Java Basics - Anfänger-Themen 2
H Liste speichern. Was lässt sich verbessern? Java Basics - Anfänger-Themen 7
P Performance Array und Liste Java Basics - Anfänger-Themen 13
M QuickSort und Liste Java Basics - Anfänger-Themen 6
N Methode um Objekte einer Liste hinzuzufügen Java Basics - Anfänger-Themen 1
B Summe von Property innerhalb einer Liste via Lambda Java Basics - Anfänger-Themen 1
V Collections int Werte in einer Liste sortieren Java Basics - Anfänger-Themen 23
B Neue Liste erstellen, wenn Objekte bestimmte Referenz hat / Gruppierung von Einträgen Java Basics - Anfänger-Themen 12
V_Fynn03 Beliebiges Element in einer Liste löschen (Java)(Lineare Datenstrukturen) Java Basics - Anfänger-Themen 9
L Baum aus Integer Liste erstellen Java Basics - Anfänger-Themen 0
CptK Koordinate in Liste suchen Java Basics - Anfänger-Themen 20
C Verschiedene Objekte in einer Liste speichern Java Basics - Anfänger-Themen 6
M Ausgabe einer Liste welche mehrere Stacks enthält Java Basics - Anfänger-Themen 3
D Doppelt Verkettete Zirkular-Liste Java Basics - Anfänger-Themen 1
L Liste in anderem Thread laden Java Basics - Anfänger-Themen 1
M Array liste Verdrehen Java Basics - Anfänger-Themen 8
A Verkettete Liste Java Basics - Anfänger-Themen 2
J Strings untereinander in einer Liste vergleichen Java Basics - Anfänger-Themen 18
B Liste von Tagen generieren ab einem bestimmten Datum und Endedatum Java Basics - Anfänger-Themen 4
S IndexOutOfBoundsException beim hinzufügen eines Elements zu einer Liste Java Basics - Anfänger-Themen 11
B Liste sortieren? Java Basics - Anfänger-Themen 4
O Anonyme Klasse einer Liste erstellen Java Basics - Anfänger-Themen 7
B SWAP List; Liste neu anordnen Java Basics - Anfänger-Themen 4
B CSS Klassen in eine Liste schreiben Java Basics - Anfänger-Themen 4
B Doppelt verkettete Liste implementieren Java Basics - Anfänger-Themen 8
L verkettete Liste Java Basics - Anfänger-Themen 15
scratchy1 doppelt verkettete Liste testen Java Basics - Anfänger-Themen 8
O ADT Liste z. B. Java Basics - Anfänger-Themen 15
B sortierte Liste Java Basics - Anfänger-Themen 4
O Knoten und Liste verarbeitung Java Basics - Anfänger-Themen 20
R Methoden Entferne alle identische Knoten (Typ String) aus verkettete Liste Java Basics - Anfänger-Themen 8
C Methoden Über eine einfach verkettete Liste Java Basics - Anfänger-Themen 8
J Eine Liste von Listen erstellen Java Basics - Anfänger-Themen 11
A Einträge aus Tupeln nach Regeln in Liste speichern Java Basics - Anfänger-Themen 8
Queiser Liste zurückgeben Java Basics - Anfänger-Themen 7
T Collections Geeignete Collection/Liste/Datenbank Java Basics - Anfänger-Themen 17
S spezielle Wörter aus Liste entfernen Java Basics - Anfänger-Themen 2
H Verkettete Liste Java Basics - Anfänger-Themen 7

Ähnliche Java Themen


Oben