74 lines
3.2 KiB
C
74 lines
3.2 KiB
C
//erstellt von Harun Faizi am 01.11.2025; Informatik 2 Praktikum; Projekt 1
|
|
#include "input.h"
|
|
#include <string.h>
|
|
#include <ctype.h>
|
|
|
|
// TODO:
|
|
// eine Funktion implementieren, die ein einzelnes Wort aus einer Textdatei (words.txt) einliest und als C-String zurückgibt.
|
|
|
|
/* Liest Wörter aus words.txt und speichert sie in ein 2D-Array "words"
|
|
Trennzeichen: Komma, Semikolon, Leerzeichen und Zeilenumbruch
|
|
|
|
file: geöffnete Datei (words.txt)
|
|
words: 2D-Array zu Speicherung der Wörter
|
|
maxWordCount: maximale Anzahl an Wörter, die eingelesen dürfen
|
|
|
|
Rückgabe: Anzahl der eingelesen Wörter (0 falls nichts gelesen oder Fehler)
|
|
*/
|
|
|
|
// Read words from file and store in 'words' array
|
|
int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount)
|
|
{ //Gibt die Anzahl der eingelesen Wörter zurück (wordCount), für main wie viel gelesen wurde
|
|
//FILE *file: Zeiger auf Datei --> FILE komplexes Objekt, müssen mit Adresse arbeiten
|
|
//word[][...]: Wort = String = Array von Zeichen (char) --> Zeilen: Wörteranzahl und Spalten: Buchstaben der Wörter
|
|
//maxWordCount: wie viele Wörter max in Array geschrieben werden dürfen
|
|
|
|
|
|
if (file == 0)
|
|
return 0; //Sicherheitsprüfung
|
|
|
|
char line[MAX_LINE_LEN]; // Puffer für eine Zeile aus Datei --> Wörter später mit strtok() aus der Zeile extrahieren
|
|
unsigned int wordCount = 0; // zählt wie viele Wörter gefunden wurden
|
|
|
|
//Lese Datei Zeile für Zeile
|
|
while(fgets(line, sizeof(line), file) != NULL) //liest Zeile für Zeile
|
|
{
|
|
// fgets: liest komplette Zeile aus Datei
|
|
// fgets(Zielfeld, maximaleLänge, DateiZeiger);
|
|
// ==> "Lies aus Datei file bis 1024 Zeichen oder bis Zeilenumbruch \n kommt und speichere das Erg. in line"
|
|
// fgets gibt NULL zurück wenn Dateiende (EOF) erreicht ist
|
|
// fgets hängt IMMER automatisch \0 ans Ende des gelesen Textes
|
|
|
|
// Zerlege die Datei in einzelne Wörter
|
|
char *token = strtok(line, ".,;\n\t");
|
|
//strtok(): "Zerlege ein String in einzelne Teile (Wörter) nach bestimmten Trennzeichen
|
|
//strtok(): ersetzt Trennzeichen mit \0, merkt sich wo aufgehört hat und macht dann weiter
|
|
//char * token: Zeiger auf ein Zeichen (Anfang eines Strings)
|
|
|
|
|
|
//"Solange es noch ein Wort gibt UND Speicherlimit noch nicht erreicht wurde, mach weiter"
|
|
while (token != NULL && wordCount < maxWordCount)
|
|
{
|
|
//aktuelles Wort in Array kopieren
|
|
strncpy(words[wordCount], token, MAX_WORD_LEN -1);//Kopiert Inhalt von token (aktuelles Wort) in das Array words
|
|
//strcpy(Ziel, Quelle, maximaleAnzahl);
|
|
|
|
words[wordCount][MAX_WORD_LEN -1] = '\0';//jedes Wort im array endet mit \0
|
|
|
|
|
|
wordCount++; //Wort gespeichert, zähle eins hoch
|
|
token = strtok(NULL, ",;\n");// sucht nächstes Wort ab Stelle, wo es aufgehört hat zuletzt
|
|
}
|
|
// Wenn max Wortzahl erreicht ist abbrechen
|
|
if (wordCount >= maxWordCount)
|
|
break;
|
|
}
|
|
|
|
return wordCount;
|
|
}
|
|
|
|
/* Arrays im Überblick:
|
|
line[]: eine Zeile aus der Datei
|
|
words[][]: alle Wörter einzelnd gespeichert
|
|
token: Zeiger auf das aktuelle Wort
|