Funkcija vfscanf () C ++ naudojama duomenims nuskaityti iš failų srauto.
Funkcija vfscanf () yra apibrėžta antraštės faile.
vfscanf () prototipas
int vfscanf (FILE * stream, const char * format, va_list vlist);
Funkcija „vfscanf ()“ nuskaito duomenis iš failų srauto ir išsaugo reikšmes atitinkamose vietose, kaip apibrėžta „vlist“.
vfscanf () parametrai
- srautas: įvesties failų srautas, iš kurio galima nuskaityti duomenis.
- formatas: žymeklis į nulinę simbolių eilutę, nurodančią, kaip skaityti įvestį. Jį sudaro formato specifikatoriai, prasidedantys%.
- „vlist“: kintamųjų argumentų sąrašas, kuriame bus saugomos reikšmės. Formato
eilutę sudaro šios dalys:- Ne tarpų simboliai, išskyrus%, kurių kiekvienas sunaudoja vieną identišką simbolį iš įvesties srauto. Tai gali sukelti funkcijos gedimą, jei kitas srauto simbolis nėra lygus.
- Baltosios erdvės simbolis: visi vienas po kito einantys simboliai yra laikomi atskirais tarpais. Toliau ' n', ' t' ir '' laikomos vienodomis.
- Konversijos specifikacija: ji pateikiama tokiu formatu:
- Pradinis% simbolis, nurodantis pradžią
- Pasirenkamas * vadinamas priskyrimą slopinančiu simboliu. Jei šis simbolis yra, „vfscanf“ () nepriskiria rezultato jokiam gaunančiam argumentui.
- Pasirenkamas teigiamas sveikasis skaičius, nurodantis maksimalų lauko plotį. Jame nurodomas maksimalus simbolių, kuriuos „vfscanf“ () leidžiama sunaudoti atliekant konversiją, nurodytą dabartinėje konversijos specifikacijoje, skaičius.
- Pasirenkamas ilgio modifikatorius, nurodantis gaunamo argumento dydį.
- Konversijos formato specifikatorius.
Formato specifikatorius apibūdinimas % Atitinka pažodinį% c Atitinka vieną ar kelis simbolius. Jei apibrėžtas plotis, tiksliai atitinka pločio simbolius. s Atitinka vienas po kito einančius simbolius be tarpų. Jei plotis yra apibrėžtas, tiksliai atitinka pločio simbolius arba tol, kol bus rastas pirmasis tarpas. (rinkinys) Atitinka ne tuščią simbolių seką iš pateikto simbolių rinkinio. Jei aibės pradžioje yra ^, tada visi nenurodyti simboliai sutampa. d Atitinka dešimtainį skaičių. i Atitinka sveiką skaičių. o Atitinka nepasirašytą aštuonetą. X arba x Atitinka nepasirašytą šešioliktainį sveikąjį skaičių. u Atitinka nepasirašytą dešimtainį skaičių. A arba a, E arba e, F arba f, G arba g Atitinka slankiojo kablelio skaičių. n Grąžina iki šiol perskaitytų simbolių skaičių. p Atitinka įgyvendinimo apibrėžtą simbolių seką, apibrėžiančią žymeklį.
Taigi bendras formato specifikatoriaus formatas yra:% (*) (plotis) (ilgis) specifikatorius
- vlist: Įvesties gavimo argumentų sąrašas.
vfscanf () Grąžinimo vertė
- Jei pavyks, funkcija vfscanf () grąžins sėkmingai perskaitytų argumentų skaičių.
- Sugedus, EOF grąžinamas.
Pavyzdys: Kaip veikia vfscanf () funkcija?
#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; )
Kai paleisite programą, galimas rezultatas bus:
Čia yra mano draugų Robertas Sydas Brianas Eddie Rayas sąrašas