Funksjonen vfscanf () i C ++ brukes til å lese dataene fra en filstrøm.
Funksjonen vfscanf () er definert i topptekstfilen.
vfscanf () prototype
int vfscanf (FIL * stream, const char * format, va_list vlist);
Funksjonen vfscanf () leser dataene fra filstrømmen og lagrer verdiene på de respektive stedene som definert av vlist.
vfscanf () Parametere
- stream: Inngang filstrøm for å lese dataene fra.
- format: peker til en null-avsluttet tegnstreng som spesifiserer hvordan du skal lese inngangen. Den består av formatspesifikatorer som begynner med%.
- vlist: Variabel argumentliste der verdiene skal lagres Formatstrengen
har følgende deler:- Ikke tegn mellomrom unntatt% som hver bruker ett identisk tegn fra inngangsstrømmen. Det kan føre til at funksjonen mislykkes hvis neste tegn på strømmen ikke sammenligner like.
- Hvitt mellomromstegn: Alle påfølgende tegn i hvitt mellomrom blir behandlet som ett hvitt mellomromstegn. Videre anses ' n', ' t' og '' som de samme.
- Konverteringsspesifikasjon: Den følger følgende format:
- Innledende% tegn som spesifiserer begynnelsen
- En valgfri * kalt oppdragsdempende karakter. Hvis dette tegnet er tilstede, tildeler ikke vfscanf () resultatet til noe mottaksargument.
- Et valgfritt positivt heltall som spesifiserer maksimal feltbredde. Den spesifiserer maksimalt antall tegn som vfscanf () har lov til å konsumere når konverteringen er spesifisert i gjeldende konverteringsspesifikasjon.
- En valgfri lengdemodifikator som angir størrelsen på mottaksargumentet.
- En konverteringsformatspesifikator.
Format Spesifikator Beskrivelse % Matcher bokstavelig% c Matcher et enkelt tegn eller flere tegn. Hvis bredde er definert, samsvarer den nøyaktig med tegn i bredden. s Matcher påfølgende ikke-mellomromstegn. Hvis bredde er definert, samsvarer den nøyaktig med tegn i bredden eller til første hvite mellomrom er funnet. (sett) Matcher en ikke-tom sekvens av tegn fra det gitte settet med tegn. Hvis er tilstede i begynnelsen av settet, samsvarer alle tegnene som ikke er i settet. d Matcher et desimaltall. Jeg Matcher et heltall. o Matcher et usignert oktalt heltall. X eller x Matcher et usignert heksadesimalt heltall. u Matcher et usignert desimaltall. A eller a, E eller e, F eller f, G eller g Matcher et flytende nummer. n Returnerer antall tegn som er lest hittil. s Matcher en implementeringsdefinert tegnsekvens som definerer en peker.
Så det generelle formatet til formatspesifikatoren er:% (*) (bredde) (lengde) spesifikator
- vlist: En liste over argumenter for å motta inngangene.
vfscanf () Returverdi
- Hvis vellykket, returnerer funksjonen vfscanf () antall argumenter som er lest.
- Ved feil returneres EOF.
Eksempel: Hvordan fungerer vfscanf ()?
#include #include void read(FILE* fp, const char * format,… ) ( va_list args; va_start (args, format); vfscanf (fp, format, args); va_end (args); ) int main () ( char myFriends(5)(20) = ("Robert", "Syd", "Brian", "Eddie", "Ray"); FILE *fp = fopen("example.txt","w+"); char name(20); for (int i=0; i<5; i++) fprintf(fp, "%s ", myFriends(i)); rewind(fp); printf("Here are the list of my friends"); for (int i=0; i<5; i++) ( read(fp, "%s ", &name); printf("%s", name); ) fclose(fp); return 0; )
Når du kjører programmet, vil en mulig utgang være:
Her er listen over vennene mine Robert Syd Brian Eddie Ray