Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Aus Datei lesen , Unicode

Empfohlene Antworten

Veröffentlicht

Hallo,

ich möchte aus einer Datei lesen aber irgendwie will getline mir nichts ausgeben

  // Open the file

  fstream f;

  f.open("111.txt", ios::in);

  if (!f.is_open())

    return Error();



  while (!f.eof())

  {

      f.getline(charstrLine, 80);

  }

  f.close();

111.txt existiert und hat Inhalt. Ich bin mir nicht sicher ob es am Unicode liegt aber selbst wenn sollte es ja irgendwas ausgeben, da die Buchstaben (ohne Umlaute) ja die selben Werte haben, oder? Ich verzweifel beinahe. Sitze schon den ganzen Anbend/Nacht. Sehen dass das nicht funktionier tu ich im Debugmodus. Die werte ändern sich nicht. habe auch schon messageboxes ausgeben wollen. geht nicht.

Infos:

c++ ;)

VS 2010

Win32 Anwendung

non MFC

keine vorkompilierte Header

nichts was ich nicht kenne ATL/STL und so ... ka was das bedeutet... alles aus.

Ich bin mir nicht sicher ob es am Unicode liegt aber selbst wenn sollte es ja irgendwas ausgeben
Im gezeigten Code ist nichts, das irgendeine Ausgabe erzeugen könnte.

Zum Code:

  • Wenn du statt fstream ifstream benutzt, kannst du dir das ios::in sparen.
  • open und close benutzt man normalerweise nicht. Für open gibt es den Konstruktor, für close den Destruktor.
  • eof eignet sich nicht als Schleifenbedingung, weil das erst dann true ergibt, wenn das Lesen schon einmal fehlgeschlagen ist.
  • Benutz besser std::getline aus <string>, dann bekommst du keine Probleme, wenn mal eine Zeile mehr als 80 Zeichen hat.

  // Open the file
ifstream f("111.txt";
while (f.getline(charstrLine, 80))
{
}[/code]

Hi De Kaisastiähla,

der folgende Ansi C Code ließt aus der Datei "C:\Text.txt" die erste Zeile aus.

Ausgegeben werden die ersten 3 Zeichen und eine Zeile tiefer im Ausgabefenster die nächsten 3 Zeichen.


{

char data_1[255]; 


char aa[255];

char bb[255];

FILE *ptr;	

ptr = fopen("C:\\Text.txt", "r");  //Textdatei öffnen

fgets(data_1, 255, ptr);          //Die Zeile wird aus der Textdatei eingelesen	

strcpy(aa, data_1);

strcpy(bb, data_1);

{

char* substr = &aa[0];

aa[3] = '\0';

printf( "Wert 1 aus Zeile 1:    '%s'\n", substr , "%s\n");

}

{

char* substr = &bb[3];

bb[6] = '\0';

printf( "Wert 2 aus Zeile 1:    '%s'\n", substr , "%s\n");

}

if( ptr != NULL )  // Wenn nichts in der Textatei steht, springe nach unten und schliesse die Datei

{

}

 fclose( ptr );		//Textdatei schliessen	

}

Ich hätte mal die Frage, wie ich denn an die letzen 3 Zeichen in der Textdatei herankommen kann, wenn diese nicht in der ersten Zeile der Textdatei stehen, sondern in der zweiten Zeile der Textdatei ?

Was müsste ich im Code dafür ändern ?

Kann mir das jemand erklären.

Gruß

Eleu

  • Autor
Im gezeigten Code ist nichts, das irgendeine Ausgabe erzeugen könnte.

Jop, testen kann ich immer nur im mit dem Debugger von VS2010, indem ich die Variablen verfolge. Das haben die echt gut gemacht. In Win32 Anwendungen ist es leider nicht so einfach etwas auszugeben à la prinntf(...) oder weitere. Überzeugt mich vom Gegenteil, würde mich sehr freuen.

Zum Code:

Wenn du statt fstream ifstream benutzt, kannst du dir das ios::in sparen.

Danke, gemacht.

open und close benutzt man normalerweise nicht. Für open gibt es den Konstruktor, für close den Destruktor.

Nochmals danke, feine Sache wenn das für mich erledigt wird. Ich muss dazu sagen, dass wir das in der Uni gelernt haben. Prof obv failed teaching C++.

eof eignet sich nicht als Schleifenbedingung, weil das erst dann true ergibt, wenn das Lesen schon einmal fehlgeschlagen ist.

Hier steht halt das getline den istream zurückgibt. Deinem Code entnehme ich dann, dass ein leerer istream NULL/0/false ist. Ist das immer so?

Benutz besser std::getline aus <string>, dann bekommst du keine Probleme, wenn mal eine Zeile mehr als 80 Zeichen hat.

Naja würde ich gern aber ich brauche hinterher nen CSting wegen seinen angenemen Operationen und Möglichkeit ihn zu kovertieren. Ich habe schon ne weile nach casts von Std::string zu jeglichen (unnötig vielen) Stringarten gesucht, aber das scheint mir nicht so einfach wie der CString. Hier habe ich eine Lösung gefunden. Nur nicht für den Std::string.

Danke für die kompetente Hilfe.

Anwendungen ist es leider nicht so einfach etwas auszugeben à la prinntf(...) oder weitere.
Mit OutputDebugString kannst du einen Text im Debug-Fenster ausgeben lassen (oder mit DebugView mitlesen).

feine Sache wenn das für mich erledigt wird.
Das Konzept nennt sich RAII

Ich muss dazu sagen, dass wir das in der Uni gelernt haben. Prof obv failed teaching C++.
Kommt vermutlich von C.

Deinem Code entnehme ich dann, dass ein leerer istream NULL/0/false ist.
So ähnlich. Wenn du ein stream-Objekt in einem Kontext benutzt, wo ein Wahrheitswehrt gefragt ist, entspricht der Wert dem negierten Rückgabewert von fail().

Ist das immer so?
Immer, wenn das badbit oder das failbit des Streams gesetzt ist: Wenn die Datei nicht geöffnet werden konnte, wenn du am Dateiende angelangt bist, wenn du mit >> in den falschen Typ einliest.

Hier habe ich eine Lösung gefunden. Nur nicht für den Std::string.
std::string ist ein typedef von std::basic_string, der ist auf dieser Seite auch gelistet.

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.