Sortieren File[]

Status
Nicht offen für weitere Antworten.

CK

Aktives Mitglied
Hallo,
habe zur Zeit so eine File[]
Code:
 File[] files = new File(directoryM).listFiles();

Jetzt lese ich z.B. solche diese Files ein:
File1.txt
File2.txt
File10.txt
File15.txt
File7.txt

Jetzt werden diese so sorrtiert:
File1.txt
File10.txt
File15.txt
File2.txt
File7.txt

Jetzt zu meiner Frage.
Wie bekomme ich es hin das diese in dieser Reihenfolge sortiert werden:
File1.txt
File2.txt
File7.txt
File10.txt
File15.txt

Für ein kleines Codebeispiel wäre ich echt dankbar.
 
S

SlaterB

Gast
erstelle dir neue Objekte einer eigenen Klasse,
darin speicherst du das File-Objekt und dazu einen int,
den du per String-Operation und Integer.parseInt aus dem Dateinamen extrahierst:
File15.txt -> 15

dann sortiere eine Liste der erstellten Objekte nach dem int-Wert,
da musst du dich über Comparable schlau machen, falls noch nicht bekannt,

-------

alternativ kannst du aus dem Int auch direkt auf die Position schließen,
z.B. File15.txt -> 15 -> File an Position 15 in eine Liste/ Array schreiben,
am Ende leere Stellen im Array/ in der Liste entfernen, falls die Namen nicht durchgehend sind


------

noch ne Idee: verwende einen Comparator, der erst nach der Länge sortiert, dann alphabetisch
 

Niki

Top Contributor
Code:
import java.io.File;
import java.util.Arrays;
import java.util.Comparator;

public class FileComparator implements Comparator<File> {

	public int compare(File o1, File o2) {
		String name1 = o1.getName();
		String name2 = o2.getName();
		
		return getInt(name1).compareTo(getInt(name2));
		
	};
	
	private Integer getInt(String name){
		int index = name.lastIndexOf(".");
		if(index == -1)
			return new Integer(0);
		
		StringBuilder sb = new StringBuilder();
		char[] c = name.toCharArray();
		for(int i = index - 1; i >= 0; i--){
			if(Character.isDigit(c[i])){
				sb.insert(0, c[i]);				
			} else {
				return Integer.parseInt(sb.toString());
			}
		}
		
		return new Integer(0);
	}
	
	public static void main(String[] args) {
		File[] f = new File[]{new File("File1.txt"), new File("File10.txt"), new File("File2.txt"), new File("File9.txt")};
		
		Arrays.sort(f, new FileComparator());
		for(File _f : f){
			System.out.println(_f.getName());
		}
	}
	
}
 

CK

Aktives Mitglied
Danke, guter Tipp.
Habe das jetzt so gemacht und es klappt.
Code:
 Arrays.sort(files, new Comparator<File>()
                {
                    public int compare(File o1, File o2)
                    {
                        String nurMitZahlen1 = "";
                        String nurMitZahlen2 = "";

                        String name = o1.getName();
                        for (int i = 0; i < name.length(); i++)
                        {
                            if (Character.isDigit(name.charAt(i)))
                            {
                                nurMitZahlen1 +=name.charAt(i);
                            }
                        }

                        name = o2.getName();
                        for (int i = 0; i < name.length(); i++)
                        {
                            if (Character.isDigit(name.charAt(i)))
                            {
                                nurMitZahlen2 += name.charAt(i);
                            }
                        }

                        if(nurMitZahlen1.equals("") || nurMitZahlen2.equals(""))
                        {
                            return 0;
                        }
                            
                        return Integer.parseInt(nurMitZahlen1) - Integer.parseInt(nurMitZahlen2);
                    }

                });
 

CK

Aktives Mitglied
Dank, habe es so gemacht und es klappt.
Code:
 Arrays.sort(files, new Comparator<File>()
                {
                    public int compare(File o1, File o2)
                    {
                        String nurMitZahlen1 = "";
                        String nurMitZahlen2 = "";

                        String name = o1.getName();
                        for (int i = 0; i < name.length(); i++)
                        {
                            if (Character.isDigit(name.charAt(i)))
                            {
                                nurMitZahlen1 +=name.charAt(i);
                            }
                        }

                        name = o2.getName();
                        for (int i = 0; i < name.length(); i++)
                        {
                            if (Character.isDigit(name.charAt(i)))
                            {
                                nurMitZahlen2 += name.charAt(i);
                            }
                        }

                        if(nurMitZahlen1.equals("") || nurMitZahlen2.equals(""))
                        {
                            return 0;
                        }
                            
                        return Integer.parseInt(nurMitZahlen1) - Integer.parseInt(nurMitZahlen2);
                    }

                });
 
S

SlaterB

Gast
performant ist das allerdings nicht,
je länger die Liste desto überproportinal mehr Vergleiche musst du ausführen (n log n),
und jeweils derart viele String-Operationen + Parsen..

vergleich dann doch lieber nach Länge + alphabetisch, das ist einfach und sollte auch hinkommen,
sofern die Dateien alle gleich heißen bis auf die Zahl
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Fynn29 Liste sortieren ohne Array und ohne vorgegebene Sortierung Allgemeine Java-Themen 24
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
L allgemein Strings händisch in Liste sortieren Allgemeine Java-Themen 47
K Verbesserung der Laufzeit beim Sortieren von Einwohnern nach ihrem Geburtsjahr Allgemeine Java-Themen 0
Willi.We Array sortieren Allgemeine Java-Themen 5
L ArrayList sortieren Allgemeine Java-Themen 2
Monokuma String List nach Zahlen und Worten sortieren Allgemeine Java-Themen 9
MiMa ArrayList sortieren?? Allgemeine Java-Themen 5
C MySQL Tabellen sortieren. Allgemeine Java-Themen 33
Curtis_MC Collections Liste anhand mehrere Kriterien sortieren Allgemeine Java-Themen 6
B Java Mail: Emails sortieren? Allgemeine Java-Themen 5
G Liste (UsageStats) sortieren (Android) Allgemeine Java-Themen 5
FRI3ND Datentypen Date-Array sortieren - Text mitnehmen? Allgemeine Java-Themen 7
P Wertepaare sortieren Allgemeine Java-Themen 3
MiMa Sortieren nach Stellenangaben Allgemeine Java-Themen 7
T Collections ArrayList Sortieren Allgemeine Java-Themen 4
P Listen sortieren Allgemeine Java-Themen 1
U Methoden Algorithmus MergeSort String [ ] array sortieren programmieren Allgemeine Java-Themen 17
S Verkettete (Teil)Liste sortieren ( rekursiv bis n) Allgemeine Java-Themen 2
K Strings sortieren: 2 Kritieren Allgemeine Java-Themen 5
B Algortihmus zum linearen Sortieren Allgemeine Java-Themen 1
K ArrayList sortieren Allgemeine Java-Themen 16
heyluigi Random Integer Array Ausgabe nach Größe sortieren Allgemeine Java-Themen 6
H Liste sortieren anhand optionalem Property Allgemeine Java-Themen 3
2 Mehrere Uhrzeiten Sortieren Allgemeine Java-Themen 2
B Counting Sort (Sortieren durch Zählen) Allgemeine Java-Themen 13
H Liste von Objekten generisch sortieren Allgemeine Java-Themen 0
Bluedaishi String Array mit Datum und Uhrzeit String sortieren Allgemeine Java-Themen 6
K Sortieren nach Vorgabe Allgemeine Java-Themen 6
S Erste Schritte Arrayliste alphabetisch sortieren mit Eingabe Allgemeine Java-Themen 9
L Sortieren von "Map<String, Object>" Allgemeine Java-Themen 2
M Sortieren und Leerzeichen Allgemeine Java-Themen 11
W Array Indizes sortieren Allgemeine Java-Themen 16
D Sortieren von Liste zu unperformant Allgemeine Java-Themen 6
E Array alphabetisch sortieren Allgemeine Java-Themen 1
5 Objekte Sortieren lassen Allgemeine Java-Themen 7
P Beim sortieren nullpointerexception Allgemeine Java-Themen 12
G Map nach key sortieren Allgemeine Java-Themen 14
T Array Sortieren (null Werte ans Ende) Allgemeine Java-Themen 2
Gossi Collections (Unbekannte) Liste Sortieren Allgemeine Java-Themen 10
S Int Values sortieren Allgemeine Java-Themen 7
S Sortieren nach Objekten Allgemeine Java-Themen 13
A 2D-array problem (sortieren) Allgemeine Java-Themen 6
T Liste mit GregorianCalendar-Objekten in List einlesen, mit Collection sortieren und ausgeben Allgemeine Java-Themen 3
D priority queue sortieren Allgemeine Java-Themen 10
G List<Person> sortieren Allgemeine Java-Themen 6
K Hashmap sortieren Allgemeine Java-Themen 6
H Problem beim Sortieren einer HashMap mit TreeSet Allgemeine Java-Themen 4
M ArrayList<String>, String häufigkeit sortieren Allgemeine Java-Themen 4
J Wie sortieren? Allgemeine Java-Themen 11
T Liste sortieren Allgemeine Java-Themen 6
K Strings sortieren (knifflig) Allgemeine Java-Themen 7
B JTable nach Icon sortieren Allgemeine Java-Themen 6
C ArrayList (mit Objekten) sortieren Allgemeine Java-Themen 12
J Map nach value sortieren Allgemeine Java-Themen 14
G Zahlen in Strings einer ArrayList sortieren Allgemeine Java-Themen 14
V ArrayList sortieren Allgemeine Java-Themen 7
S String-Array nach Datum sortieren Allgemeine Java-Themen 10
Developer_X Ein Array nach einem bestimmten Attribut sortieren Allgemeine Java-Themen 3
B Sortieren mit generischen Datentypen Allgemeine Java-Themen 3
C ArrayList anhand von zwei Attributen sortieren Allgemeine Java-Themen 4
O Sortieren von Telefonnummern Allgemeine Java-Themen 8
D JTabel sortieren nach mehreren kriterien Allgemeine Java-Themen 3
G Verschachtelte Treemaps, nach Value sortieren Allgemeine Java-Themen 11
K ArrayList nach bestimmtem Muster sortieren Allgemeine Java-Themen 3
I Vector mit Objekten sortieren,Videos mit JMF wiedergeben Allgemeine Java-Themen 6
S Koordinatentupel-Map sortieren?? Allgemeine Java-Themen 16
C ArrayList sortieren (mehrere Kriterien) Allgemeine Java-Themen 6
G ArrayList mit quicksort sortieren Allgemeine Java-Themen 9
Spot84 Vector nach Ressourcetyp sortieren Allgemeine Java-Themen 4
G sortieren von generics Allgemeine Java-Themen 10
Z Als Final deklarierte Klasse im Array sortieren Allgemeine Java-Themen 2
C ArrayList nach Datum sortieren Allgemeine Java-Themen 7
O ArrayList sortieren Allgemeine Java-Themen 8
G ArrayList mit Indices parallel sortieren Allgemeine Java-Themen 8
D HashMap sortieren Allgemeine Java-Themen 2
W [solved] Vector sortieren (Collection / Comparable?) Allgemeine Java-Themen 7
D LinkedList anhand einer long-Variable der Objekte sortieren Allgemeine Java-Themen 5
O Vektoren in Vektor sortieren aber mit Java 1.4 (!) Allgemeine Java-Themen 4
T TreeMap durch Comparator mit Generics sortieren Allgemeine Java-Themen 9
M ArrayList sortieren - HashMap mit sort_id vorhanden Allgemeine Java-Themen 2
A Sortieren mit Java Allgemeine Java-Themen 3
J Properties sortieren Allgemeine Java-Themen 6
T HashMap (String, Object(String , int)) nach int sortieren Allgemeine Java-Themen 7
E Bitte um Rat: Sortieren mit ArrayList Allgemeine Java-Themen 2
G Strings die Zahlen enthalten sinnvoll sortieren (A2 < A10 Allgemeine Java-Themen 4
G List mit selbstdefinierten Objekten sortieren Allgemeine Java-Themen 2
F Doppelt verkettete Liste sortieren? Allgemeine Java-Themen 8
S ArrayList nach mehreren Spalten sortieren? Allgemeine Java-Themen 13
G Set absteigend Sortieren Allgemeine Java-Themen 6
B ein spezielles Byte-Array sortieren Allgemeine Java-Themen 11
D Sortieren? Allgemeine Java-Themen 13
N ArrayList sortieren Allgemeine Java-Themen 10
L Nach Häufigkeit sortieren Allgemeine Java-Themen 6
S Dten im Excel sortieren Allgemeine Java-Themen 5
Z Elemente in Vector nach Häufigkeit sortieren. Allgemeine Java-Themen 13
H Objekte Sortieren Allgemeine Java-Themen 4
F Kann man String[] sortieren? Allgemeine Java-Themen 2
H will einfach nicht sortieren! Allgemeine Java-Themen 23
T Collections/Arrays sortieren => ä, ö, ü, ß Groß/klein Allgemeine Java-Themen 3

Ähnliche Java Themen


Oben