kommentiert
This commit is contained in:
parent
16ab4a59ab
commit
5d13734da6
41
input.c
41
input.c
@ -1,4 +1,4 @@
|
||||
//erstellt von Harun Faizi am 01.11.2025
|
||||
//erstellt von Harun Faizi am 01.11.2025; Informatik 2 Praktikum; Projekt 1
|
||||
#include "input.h"
|
||||
#include <string.h>
|
||||
#include <ctype.h>
|
||||
@ -20,32 +20,46 @@
|
||||
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
|
||||
//Wort = String = Array von Zeichen (char) --> Zeilen: Wörteranzahl und Spalten: Buchstaben der Wörter
|
||||
//wie viele Wörter max in Array geschrieben werden dürfen
|
||||
//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
|
||||
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)
|
||||
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);
|
||||
words[wordCount][MAX_WORD_LEN -1] = '\0';
|
||||
strncpy(words[wordCount], token, MAX_WORD_LEN -1);//Kopiert Inhalt von token (aktuelles Wort) in das Array words
|
||||
//strcpy(Ziel, Quelle, maximaleAnzahl);
|
||||
|
||||
wordCount++;
|
||||
token = strtok(NULL, ",;\n");
|
||||
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!
|
||||
// Wenn max Wortzahl erreicht ist abbrechen
|
||||
if (wordCount >= maxWordCount)
|
||||
break;
|
||||
}
|
||||
@ -53,6 +67,7 @@ int readWords(FILE *file, char words[][MAX_WORD_LEN], unsigned int maxWordCount)
|
||||
return wordCount;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* Arrays im Überblick:
|
||||
line[]: eine Zeile aus der Datei
|
||||
words[][]: alle Wörter einzelnd gespeichert
|
||||
token: Zeiger auf das aktuelle Wort
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user