Funkcija vfscanf () v jeziku C ++ se uporablja za branje podatkov iz datotečnega toka.
Funkcija vfscanf () je definirana v datoteki glave.
prototip vfscanf ()
int vfscanf (FILE * tok, format const char *, seznam va_list vlist);
Funkcija vfscanf () bere podatke iz toka datotečnega toka in shranjuje vrednosti na ustrezna mesta, kot jih določa vlist.
parametri vfscanf ()
- stream: vnesite tok datoteke, iz katerega želite brati podatke.
- format: kazalec na ničelni niz znakov, ki določa, kako prebrati vnos. Sestavljen je iz specifikatorjev formata, ki se začnejo z%.
- vlist: Seznam spremenljivk argumentov, kjer naj se vrednosti shranijo
. Niz oblike vsebuje naslednje dele:- Nebeli presledki, razen%, od katerih vsak porabi en enak znak iz vhodnega toka. Funkcija lahko odpove, če se naslednji znak v toku ne primerja enako.
- Presledek: Vsi zaporedni presledki se obravnavajo kot posamezni presledki. Poleg tega se šteje, da ", t" in "" enaki.
- Specifikacija pretvorbe: Sledi naslednji obliki:
- Začetni znak%, ki določa začetek
- Izbirni *, imenovan znak za preprečevanje dodelitve. Če je ta znak prisoten, vfscanf () ne dodeli rezultata nobenemu prejemnemu argumentu.
- Izbirno pozitivno celo število, ki določa največjo širino polja. Določa največje število znakov, ki ga sme vfscanf () porabiti pri pretvorbi, določeni s trenutno specifikacijo pretvorbe.
- Izbirni modifikator dolžine, ki določa velikost sprejemnega argumenta.
- Specifikator pretvorbenega formata.
Format Specifier Opis % Ujema se z dobesednim% c Ujema se z enim ali več znaki. Če je širina definirana, se natančno ujema s širinami. s Ujema se z zaporednimi znaki, ki niso presledki. Če je širina določena, se natančno ujema s širinskimi znaki ali dokler ne najdemo prvega presledka. (nastavljeno) Ujema se s praznim zaporedjem znakov iz danega nabora znakov. Če je na začetku nabora, se ujemajo vsi znaki, ki niso v naboru. d Ujema se z decimalnim celim številom. jaz Ujema se s celim številom. o Ujema se z nepodpisanim osmiškim številom. X ali x Ujema se s šestnajstiškim neštetim celim številom. u Ujema se z nepodpisanim decimalnim celim številom. A ali a, E ali e, F ali f, G ali g Ujema se s številom s plavajočo vejico. n Vrne število doslej prebranih znakov. str Ujema se z zaporedjem znakov, definiranim z izvedbo, ki definira kazalec.
Tako je splošna oblika specifikatorja oblike:Specifikator% (*) (width) (length)
- vlist: seznam argumentov za prejemanje vhodov.
vfscanf () Vrnjena vrednost
- Če je funkcija vfscanf () uspešna, vrne število uspešno prebranih argumentov.
- V primeru okvare se vrne EOF.
Primer: Kako deluje funkcija 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; )
Ko zaženete program, bo možen izhod:
Tu je seznam mojih prijateljev Robert Syd Brian Eddie Ray