Strings die Zahlen enthalten sinnvoll sortieren (A2 < A10

Status
Nicht offen für weitere Antworten.
G

Guest

Gast
Hi Leute,

hat zufällig schonmal jemand einen vernünftigen StringComparator geschrieben, der auch Zahlen in Strings erkennt und sinnvoll sortieren kann? Ich hab jetzt das Problem dass das compareTo von String das meint: A1 < A10 < A2 < A3. Weil die 10 nicht zusammenhängend ausgewertet wird.

Oder hat jemand einen Ansatz mit dem ich schnell an mein Ziel komme? Eine statische Lösung (einfach "A" abschneiden) wird nicht funktionieren, da auch vollkommen andere Strings vorkommen könnten.

Danke schonmal im Voraus! :)

Gruß Nova
 

Marco13

Top Contributor
Ich kenne nur wenige "alltägliche" Probleme, bei denen Regular Expressions eine passende Lösung darstellen, aber DAS wäre eine: Damit kann man relativ leicht Zahlen in Strings finden, die man dann einfach rausparsen kann.
 
G

Guest

Gast
Hm, das wäre dann aber ein ziemlich komplexer Regular Expression, weil ja nicht nur die Zahlen rausgeparsed und vergleichen, sondern auch die restlichen Strings zwischen den Zahlen berücksichtigt werden müssen. Und mit Regular Expressions kenne ich mich nicht wirklich gut aus... :-(
 

Marco13

Top Contributor
Ich auch nicht. Wieder dieser alte Spruch: "Wenn du ein Problem hast, und jemand sagt, du solltest es mit RegularExpressions lösen, hast du auf einmal ZWEI Probleme" :wink: Aber in diesem Fall ist die Regular Expression selbst garnicht so kompliziert: "\\d+". Etwas fummeliger ist, die ganzen matches durchzugehen, und im richtigen Moment richtig zu returnen. Was bei einem Vergleich zweier Strings wie
abc012def
abc12def
rauskommen soll (beide male steht "eigentlich" nur 12 da...) mal ganz außen vor gelassen.

Hab da mal was gebastelt - ist aber nicht so ausführlich getestet und nur ziemlich schnell hingeschrieben - das könnte man vmlt. schöner, einfacher, eleganter, was-weiß-ich-wie machen, aber vielleicht hilft's zumindest als ansatz...
Code:
import java.util.regex.*;
import java.util.*;
import java.io.*;

class NumberStringComparator implements Comparator<String>
{
    public static void main(String args[])
    {
        NumberStringComparator n = new NumberStringComparator();

        System.out.println(n.compare("abc","abc")==0);
        System.out.println(n.compare("abc12","abc")>0);
        System.out.println(n.compare("abc12","abc12")==0);
        System.out.println(n.compare("abc9","abc10")<0);
        System.out.println(n.compare("abc12def5","abc12def34")<0);
        System.out.println(n.compare("abc12def34ghi","abc12def34ghi")==0);
        System.out.println(n.compare("abc012def","abc12def"));
    }

    private Pattern pattern = Pattern.compile("\\d+");

    public int compare(String s0, String s1)
    {
        // Early return for equal strings
        if (s0.equals(s1))
        {
            return 0;
        }

        Matcher matcher0 = pattern.matcher(s0);
        Matcher matcher1 = pattern.matcher(s1);

        int prevIndex = 0;
        int startIndex = 0;

        // Compare character sequences and numbers in the input strings
        // as long as numbers are found in both strings
        boolean found0 = false;
        boolean found1 = false;
        do
        {
            found0 = matcher0.find();
            found1 = matcher1.find();

            if (found0 && found1)
            {
                // Compute the segments of characters in both strings
                // that precede the next number
                startIndex = matcher0.start();
                String segment0 = s0.substring(prevIndex, startIndex);
                startIndex = matcher1.start();
                String segment1 = s1.substring(prevIndex, startIndex);
                prevIndex = matcher1.end();

                // If the numbers occur at different positions in
                // the strings, perform a simple string comparison
                if (segment0.length() != segment1.length())
                {
                    return segment0.compareTo(segment1);
                }
                else
                {
                    // If the numbers occur at the same positions,
                    // compare the preceding string segments
                    int result = segment0.compareTo(segment1);
                    if (result != 0)
                    {
                        return result;
                    }
                }

                // Found two numbers at the same position in the
                // strings, and the preceding string segments
                // are equal. Compare the numbers.
                int number0 = Integer.parseInt(matcher0.group());
                int number1 = Integer.parseInt(matcher1.group());
                if (number0 != number1)
                {
                    return number0 - number1;
                }
            }
        }
        while (found0 && found1);

        // Strings do not contain any (more) numbers, and no difference could
        // be found yet. Perform a simple string comparison
        return s0.compareTo(s1);
    }

}
 

Marco13

Top Contributor
Jo, zum Beispiel mit einer Regex, die abwechselnd Zahl-Strings und Nicht-Zahl-Strings liefert, damit man sich die indizes sparen und leichter vergleichen kann... Aber .... naja :roll:
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Zahlen in Strings einer ArrayList sortieren Allgemeine Java-Themen 14
D Zahlen innerhalb eines Strings auslesen Allgemeine Java-Themen 3
O regulärer Ausdruck zum durchsuchen eines Strings verwenden Allgemeine Java-Themen 2
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
W JSON parsen eines ,mit JS.stringify erstellten Strings Allgemeine Java-Themen 27
L allgemein Strings händisch in Liste sortieren Allgemeine Java-Themen 47
N MySQL mit Strings Allgemeine Java-Themen 3
T Letztes Zeichen eines Strings enfernen Allgemeine Java-Themen 14
P Strings: equals vs == Allgemeine Java-Themen 47
G Objekte mit Strings Aufrufen Allgemeine Java-Themen 8
W Collections Suche Collection, um Strings mit Indizees versehen Allgemeine Java-Themen 47
V Datentypen Graphikrechner 2/Strings und Variablen in Doubles umwandeln Allgemeine Java-Themen 6
LimDul Mittels Streams aus Strings A B C den String A, B und C machen Allgemeine Java-Themen 12
Meeresgott Best Practice Strings auf Inhalte vergleichen Allgemeine Java-Themen 1
N DNA Strings vergleichen Allgemeine Java-Themen 1
Q-bert Strings aus der JList in eine Datenbank speichern Allgemeine Java-Themen 1
K Vergleich von Strings von Objekten Allgemeine Java-Themen 4
J Strings int textdokumente speicher Allgemeine Java-Themen 3
KeVoZ_ Nacheinander folgende Strings in Textdokument auf neue Zeile schreiben Allgemeine Java-Themen 6
K Strings sortieren: 2 Kritieren Allgemeine Java-Themen 5
A Vector Strings in Array splitten Allgemeine Java-Themen 6
B Wie vergleiche ich Strings in einer Liste? Allgemeine Java-Themen 5
T Strings über Bluetooth zwischen PC,µc oder Samrtphone senden und empfangen Allgemeine Java-Themen 0
N Methoden Methoden einer Klasse auf Grundlage eines Strings aufrufen Allgemeine Java-Themen 6
K Bestimmten Bereich eines Strings lesen Allgemeine Java-Themen 6
H RegularExpression zwischen zwei Strings Allgemeine Java-Themen 2
Neumi5694 Operatoren regEx für das Erstellen eines Strings verwenden Allgemeine Java-Themen 3
H Strings vergleichen Allgemeine Java-Themen 9
O Mustererkennung in Strings Allgemeine Java-Themen 4
Y String-Collection: längste gemeinsame Strings / Prefixe Allgemeine Java-Themen 3
F Problem mit Strings Allgemeine Java-Themen 8
D Strings chemisch splitten Allgemeine Java-Themen 3
K Wörter in Strings zählen Allgemeine Java-Themen 7
L Strings nach sortiertem String zurück ordnen Allgemeine Java-Themen 0
L Strings nach gleichem Muster ordnen Allgemeine Java-Themen 4
L Fragen für Facharbeit: Analyse von Strings in Java Allgemeine Java-Themen 4
D Strings vergleichen; Komma ignorieren Allgemeine Java-Themen 3
K Java Operatoren mit Strings darstellen Allgemeine Java-Themen 8
G Strings erzeugen Allgemeine Java-Themen 20
B HTML Tags in Strings umwandeln Allgemeine Java-Themen 4
N Input/Output Vergleich von identischen Strings schlägt fehl Allgemeine Java-Themen 5
U Große Liste von Strings mit indiziertem Zugriff Allgemeine Java-Themen 31
A ,,Textformatierungsbefehle" für strings deaktivieren Allgemeine Java-Themen 8
S Strings vergleichen Allgemeine Java-Themen 11
C Strings in Excel einlesen! Allgemeine Java-Themen 2
S Strings gehen "kaputt" wenn ich in CVS ein und wieder auschecke. Allgemeine Java-Themen 2
X Datentypen Prozentualer Abgleich zwischen 2 Strings (Pattern?) Allgemeine Java-Themen 3
R MD5-Hash eines Strings bestimmen Allgemeine Java-Themen 2
C Strings und JSON Objekte so klein wie möglich im Speicher ablegen Allgemeine Java-Themen 5
J String zerlegen in einzelne Strings Allgemeine Java-Themen 7
F Konstanten mir Strings "verknuepfen" Allgemeine Java-Themen 10
1 zwei Strings vergleichen Allgemeine Java-Themen 16
L Object Instanz anhand eines Strings Allgemeine Java-Themen 10
S vector & strings Allgemeine Java-Themen 26
N Strings mit null wiedergabe Splitten Allgemeine Java-Themen 4
K Strings sortieren (knifflig) Allgemeine Java-Themen 7
P Codierung der strings umändern Allgemeine Java-Themen 10
F 2 Strings zusammenfügen Allgemeine Java-Themen 2
D Strings von HTML befreien Allgemeine Java-Themen 17
S Strings zu Color-Instanzen parsen? Allgemeine Java-Themen 7
C Strings zwischen 2 Zeichen auslesen Allgemeine Java-Themen 7
T Explizite Typkonversation mit Strings Allgemeine Java-Themen 9
R Locale spezifische DateFormat Strings? Allgemeine Java-Themen 3
M Wie kann ich alle System.out Strings in ein log window umleiten? Allgemeine Java-Themen 6
R Java function die Strings escaped, sodass ich sie in Javascript verwenden kann? Allgemeine Java-Themen 4
ruutaiokwu objektreferenz eines strings... Allgemeine Java-Themen 9
data89 [Kurze Frage] Ähnlichkeit zweier Strings ermitteln Allgemeine Java-Themen 19
S bestimmte Strings spliten! Allgemeine Java-Themen 7
M Warum Strings mit equals vergleichen... Allgemeine Java-Themen 6
Daniel_L Suche nach ganzen Wörtern (wholeword) in Strings? Allgemeine Java-Themen 4
A Strings joinen, Standard-Library? Allgemeine Java-Themen 9
Y Mal wieder vergleichen von Strings.[Leider noch ein Problem] Allgemeine Java-Themen 18
data89 Die Größe eines Strings in Byte berechnen? Allgemeine Java-Themen 12
A Auslesen von Strings aus einer xls-Datei Allgemeine Java-Themen 16
G Spezialfrage zu Strings Allgemeine Java-Themen 11
C Textteile aus Strings extrahieren? Allgemeine Java-Themen 6
J Teile eines Strings ersetzen Allgemeine Java-Themen 2
G schnell Strings vergleichen Allgemeine Java-Themen 4
J Name eines Strings durch einen String festlegbar? Allgemeine Java-Themen 2
G Strings zerlegen und substrings auslesen Allgemeine Java-Themen 2
Z Letztes zeichen eines strings löschen Allgemeine Java-Themen 3
V Speicherplatz eines Strings? Allgemeine Java-Themen 12
H MIDlets und Strings Allgemeine Java-Themen 2
C Pixelanzahl eines Strings ermitteln Allgemeine Java-Themen 12
T Strings darf nur Ziffern, +/- haben Allgemeine Java-Themen 9
A Fehler beim Ersetzen eines Strings Allgemeine Java-Themen 3
G byte[] mit Strings füllen Allgemeine Java-Themen 2
H strings in datei verschlüsseln , auslesen mit klartext aber! Allgemeine Java-Themen 2
F Strings in JList ausrichten/links/rechts/mittig Allgemeine Java-Themen 10
M String#equals(), Probleme mit großen Strings? Allgemeine Java-Themen 4
H ein Teil des Strings rausfiltern Allgemeine Java-Themen 8
E Viele if Abfragen auf viele Strings --> Alternative zu if Allgemeine Java-Themen 8
C Strings zu groß um damit zu arbeiten Allgemeine Java-Themen 31
V Lib für Strings suchen und ersetzen (erweitert) Allgemeine Java-Themen 3
P Schnelles Auslesen von Strings für Syntaxhighlighting? Allgemeine Java-Themen 2
X Strings aus einer ArrayList zählen Allgemeine Java-Themen 11
C HASH Algorithmus 2 Strings ergeben das Selbe. Allgemeine Java-Themen 2
G Datei zeilenweise in Strings speichern Allgemeine Java-Themen 36
S Methode zum Zählen von Buchstaben in Strings gesucht Allgemeine Java-Themen 11
I vergleich und zählen von Strings Allgemeine Java-Themen 7

Ähnliche Java Themen

Neue Themen


Oben