Meine Frage ist ähnlich zu dieser Frage, aber mit ein paar verschiedenen Einschränkungen:
- Ich habe eine große
\n
Wortliste mit Trennzeichen - ein Wort pro Zeile. Die Dateigröße reicht von 2 GB bis zu 10 GB. - Ich muss alle doppelten Zeilen entfernen.
- Der Prozess kann die Liste während des Entfernens der Duplikate sortieren, ist jedoch nicht erforderlich.
- Auf der Partition ist genügend Platz, um die neu ausgegebene eindeutige Wortliste aufzunehmen.
Ich habe beide Methoden ausprobiert, aber beide scheitern mit Fehlern aufgrund von Speichermangel.
sort -u wordlist.lst > wordlist_unique.lst
awk '!seen[$0]++' wordlist.lst > wordlist_unique.lst
awk: (FILENAME=wordlist.lst FNR=43601815) fatal: assoc_lookup: bucket-ahname_str: can't allocate 10 bytes of memory (Cannot allocate memory)
Welche anderen Ansätze kann ich versuchen?