|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
[C++]Problema di I/0 su file
Voglio leggere una determinata stringa che ho precedentemente salvato e leggerla fino ad un carattere stabilito( %end ).
Ho provato cosi: Codice:
#include <iostream>
#include <sstream>
#include <fstream>
#include <string>
using namespace std;
int main()
{
return 0;
}
void scrivi(string nome, string text)
{
string cosa;
stringstream temp_write;
ofstream out(nome.c_str());
temp_write << text;
text = temp_write.str();
out << text << "%end" << text;
out.close();
}
string leggi(string nome)
{
string cosa;
stringstream temp_read;
ifstream in(nome.c_str());
while(in.get() != "%end")
{
temp_read << in.put();
}
cosa = temp_read.str();
return cosa;
}
C:/Documents and Settings/Admin/Desktop/Test.cpp:29: ISO C++ forbids comparison between pointer and integer C:/Documents and Settings/Admin/Desktop/Test.cpp:31: no matching function for call to `std::basic_ifstream<char, std::char_traits<char> >: .-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-. Ciao da Kleidemos C++ Programmer .-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-. |
|
|
|
|
|
#2 |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
Cosi nn compare nulla
Codice:
#include <iostream>
#include <cstdio>
#include <sstream>
#include <fstream>
#include <string>
using namespace std;
void scrivi(string, string);
string leggi(string);
int main()
{
int sc;
string test = "this.txt", txt = "ioioio";
scrivi(test, txt);
cin >> sc;
if(sc == 1)
{
cout << leggi(test) << endl;
}
system("PAUSE");
return 0;
}
void scrivi(string nome, string text)
{
stringstream temp_write;
ofstream out(nome.c_str());
temp_write << text;
text = temp_write.str();
out << text << "%end%" << "ciao";
out.close();
}
string leggi(string nome)
{
string out, tmp, temp_read;
bool trovato = false;
ifstream in(nome.c_str());
while (in.good())
{
temp_read = in.get();
}
while(temp_read != "\0")
{
if(temp_read == "%end%")
{
out = temp_read;
trovato = true;
}
if(trovato)
continue;
}
in.close();
return out.c_str();
}
|
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
|
io per ricercare una stringa mi sono scritto questa banalità; se può esserti utile
Codice:
#include "fstream.h"
#include "istream.h"
ifstream f( "filename.txt" );
string buf , findmystring = "cosa trovare";
while( f )
{
getline( f , buf );
for(int i=0;i < (int)buf.length();i++)
if(buf.substr(i,findmystring.length()) == findmystring)
printf(%s",buf.c_str());
}
|
|
|
|
|
|
#4 | |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
Ecco quel che il prog deve fare:
Quote:
E che le funz leggi nn mi legge! P.S: ho fatto male ad usare lo strinstream? |
|
|
|
|
|
|
#5 |
|
Bannato
Iscritto dal: Feb 2003
Città: genova
Messaggi: 130
|
non puoi usare il terzo parametro di getline per dire dove smettere di leggere????
cmq io ho provato un ciclo di questo tipo while (!canale.eof()) e funziona ciao |
|
|
|
|
|
#6 |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
tnk!
Ma cosi non va: Codice:
#include <iostream>
#include <cstdio>
#include <sstream>
#include <fstream>
#include <string>
using namespace std;
void scrivi(string, string);
string leggi(string);
int main()
{
int sc;
string test = "this.txt", txt = "ioioio";
scrivi(test, txt);
cin >> sc;
if(sc == 1)
{
cout << leggi(test) << endl;
}
system("PAUSE");
return 0;
}
void scrivi(string nome, string text)
{
stringstream temp_write;
ofstream out(nome.c_str());
temp_write << text;
text = temp_write.str();
out << text << "%end%" << "ciao";
out.close();
}
string leggi(string nome)
{
string out, temp_read;
bool trovato = false;
ifstream in(nome.c_str());
while (!in.eof())
{
temp_read = in.get();
}
out = temp_read.substr( 0, temp_read.find( "%end" ) );
in.close();
return out.c_str();
}
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Jan 2000
Messaggi: 551
|
Scusate vado di fretta :ve lo spiego a voce
Vi complicate la vita inutilmente: 1-caricare tutto il file in una stl string 2-usare il metodo find della stringa che ritorna un iteratore diverso da end (oppure npos)se esiste la stringa da cercare. 3-leggi la stringa originale da tuastringa.begin() a iteratore_trovato_della_stringadacercare. Sempre che io non abbia capito fischi per fiaschi della domanda |
|
|
|
|
|
#8 |
|
Bannato
Iscritto dal: Feb 2003
Città: genova
Messaggi: 130
|
prova a usare getline(array_di_memorizzazione, grandezza_array,'%end%) senza alcun ciclo
|
|
|
|
|
|
#9 | |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
Quote:
Skusate, ma sono molto niucco |
|
|
|
|
|
|
#10 |
|
Bannato
Iscritto dal: Feb 2003
Città: genova
Messaggi: 130
|
getline regge tre parametri:
il primo è la variabile dove vuoi memorizzare quello che legge il secondo è la dimensone massima da leggere il terzo è il carattere che cerca prima di finire la lettura se non inserisci il terzo parametro rimane di default '\n' (cioè a capo) se tu ci metti '%end%' aspetta di trovare %end% prima di finire la lettura. onde evitare errori è stata comunqeu data la precedenza al 2° parametro: se lo imposti a 40 e arriva a 40 caratteri senza trovare quello che cerca la lettura si interrompe comunque. |
|
|
|
|
|
#11 |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
Codice:
string leggi(string nome)
{
string out, temp_read;
bool trovato = false;
ifstream in(nome.c_str());
while (in)
{
getline(out,/* che ci metto */ ,'%end%);
}
in.close();
return out.cstr();
}
|
|
|
|
|
|
#12 |
|
Bannato
Iscritto dal: Feb 2003
Città: genova
Messaggi: 130
|
su un array metti la sua dimensione, ma dato che usi una stringa metti un numero che sia abbastanza alto da far arrivare il programma all'%end&, e abbastanza basso da non tenere 20 gb di memoria
senza un array puoi scegliere tu... volendo potresti leggere le dimensioni del file in byte e inserire il limite di conseguenza, ma non so se ne vale la pena, dipende dall'uso del programma... (se legge file dove al massimo vi sono 10000 caratteri puoi mettere il limite tranquillamente in base a questo) |
|
|
|
|
|
#13 |
|
Bannato
Iscritto dal: Feb 2003
Città: genova
Messaggi: 130
|
ps: il ciclo non serve, a meno che tu non abbia più di un %end% nel file
|
|
|
|
|
|
#14 |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
intendi cosi?
Codice:
string leggi(string nome)
{
string out;
ifstream in( nome.c_str() );
in.getline(out, 500 ,'%end%');
in.close();
return out.c_str();
}
Sono scarso come idee, vero? |
|
|
|
|
|
#15 |
|
Bannato
Iscritto dal: Feb 2003
Città: genova
Messaggi: 130
|
si, intendo così..
dovrebbe andare, sebbene non abbia mai usato c_str() |
|
|
|
|
|
#16 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
verloc...sinceramente il fatto di caricare l'intero file in una stringa non mi piace molto... Pensa se l'intero file fosse 2 Gb cosa succederebbe...
IMHO bisogna sempre mettersi nelle condizioni peggiori... ultio: leggere con getline non si puà perchè il delimitatore deve essere un solo carattere... Io lo farei così... L'ho un po' ampliato per utilizzare qualsiasi delimitatore... Codice:
#include <iostream>
#include <fstream>
#include <string>
using namespace std;
void scrivi(string nome, string text)
{
//L'avevi incasinato un po'...perchè hai usato stringstream ?
ofstream out(nome.c_str(), ios::app | ios::out);
out << text << "%end";
out.close();
}
//se apri e chiudi tutte le volte il file non ti avanzerà mai e leggerai
//sempre la prima stringa
#define BUFFER_LEN 1024
bool leggi(ifstream &in, string &text, const char *delim)
{
static string data;
char buff[BUFFER_LEN+1];
while(1)
{
if(data.size() > 0)
{
int pos = data.find(delim);
if(pos != string::npos)
{
text = data.substr(0, pos);
data = data.substr(pos+4);
return true;
}
}
if(in.eof())
{
text = data;
return false;
}
in.read(buff, BUFFER_LEN);
buff[in.gcount()] = '\0';
data += buff;
}
return false;
}
int main()
{
scrivi("pippo.txt", "ciao");
scrivi("pippo.txt", "ciao2");
ifstream in("pippo.txt");
string text;
while(leggi(in, text, "%end")) cout << text << endl;
in.close();
return 0;
}
|
|
|
|
|
|
#17 |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
me lo spieghi meglio??
Cosi imparo e so risolverlo se mi capita ancora! cmq........ tnk a tutti x la pazienza |
|
|
|
|
|
#18 |
|
Bannato
Iscritto dal: Feb 2003
Città: genova
Messaggi: 130
|
ok, ne aprofitto...
se voglio gestire il file come binario? (ad esempio jpg e avi???) parlo di un semplice copia-incolla, ma prima lo voglio memorizzare (come winmx o kazaa) durante il download |
|
|
|
|
|
#19 | |
|
Bannato
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
|
Re: [C++]Problema di I/0 su file
Quote:
La cosa piu' semplice secondo me e' questa: Codice:
#include <string> #include <iostream> using namespace std; /* ... */ ifstream in(...); // il file da dove leggere string s; // la "destinazione" char c; // il "terminatore" getline( in , s , c ); |
|
|
|
|
|
|
#20 | |
|
Bannato
Iscritto dal: Nov 2002
Città: PV
Messaggi: 1210
|
Re: [C++]Problema di I/0 su file
Quote:
P.S: ma perche nn posso utilizzare stringstream cionci? |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 00:58.



















