Funkcija fwscanf () na C ++ čita široki znak iz struje datoteka.
Funkcija fwscanf () definirana je u zaglavnoj datoteci.
prototip fwscanf ()
int fwscanf (FILE * stream, const wchar_t * format, …);
Funkcija fwscanf () čita podatke iz toka datoteka i pohranjuje vrijednosti u odgovarajuće varijable.
fwscanf () parametri
- stream: tok ulazne datoteke iz kojeg se čitaju podaci.
- format: pokazivač na niz znakova završenih nulom koji specificira način čitanja unosa. Sastoji se od specifikatora formata koji počinju s%.
Niz formatiranja ima sljedeće dijelove:- Znakovi koji nisu razmaci, osim% koji svaki troši po jedan identičan znak iz ulaznog toka. To može uzrokovati neuspjeh funkcije ako se sljedeći znak u streamu ne usporedi.
- Razmak: Znakovi razmaka uzastopno tretiraju se kao jedan razmak. Nadalje, ' n', ' t' i '' smatraju se istim.
- Specifikacija pretvorbe: Slijedi sljedeći format:
- Inicijalni% znak koji specificira početak
- Izborni * koji se naziva znak za suzbijanje dodjele. Ako je prisutan ovaj znak, fwscanf () ne dodjeljuje rezultat niti jednom argumentu primanja.
- Izborni pozitivni cijeli broj koji specificira maksimalnu širinu polja. Određuje maksimalan broj znakova koje fwscanf () smije upotrijebiti prilikom izvršavanja pretvorbe određene trenutnom specifikacijom pretvorbe.
- Izborni modifikator duljine koji specificira veličinu argumenta koji prima.
- Specifikator formata pretvorbe.
Specifikator formata Opis % Podudara se s doslovnim% c Podudara se s jednim znakom ili više znakova. Ako je širina definirana, točno se podudara sa znakovima širine. s Podudara se s uzastopnim znakovima koji nisu razmaci. Ako je širina definirana, točno se podudara sa znakovima širine ili dok se ne pronađe prvi razmak. (postavljeno) Podudara se s praznim nizom znakova iz zadanog skupa znakova. Ako je prisutan na početku skupa, tada se podudaraju svi znakovi koji nisu u skupu. d Podudara se s decimalnim cijelim brojem. ja Podudara se s cijelim brojem. o Podudara se s nepotpisanim osminski cijelim brojem. X ili x Podudara se s nepotpisanim heksadecimalnim cijelim brojem. u Podudara se s nepotpisanim decimalnim cijelim brojem. A ili a, E ili e, F ili f, G ili g Podudara se s brojem s pomičnom zarezom. n Vraća broj do sada pročitanih znakova. str Podudara se s implementacijom definiranim slijedom znakova koji definira pokazivač.
Dakle, općeniti format specifikatora formata je:Specifikator% (*) (width) (length)
- …: Ostali dodatni argumenti za primanje podataka. Javljaju se u slijedu prema specifikatoru formata.
fwscanf () Povratna vrijednost
- Funkcija fwscanf () vraća broj uspješno dodijeljenih argumenata za primanje.
- Ako se neuspjeh dogodi prije nego što je dodijeljen prvi argument primanja, vraća se EOF.
Primjer: Kako funkcionira funkcija fwscanf ()?
#include #include #include #include int main() ( FILE *fp = fopen("example.txt","w+"); wchar_t str(10), ch; setlocale(LC_ALL, "en_US.UTF-8"); fwprintf(fp, L"%ls %lc", L"Summation", L'u2211'); fwprintf(fp, L"%ls %lc", L"Integral", L'u222b'); rewind(fp); while((fwscanf(fp, L"%ls %lc", str, &ch))!=EOF) ( wprintf(L"%lc is %ls", ch, str); ) fclose(fp); return 0; )
Kada pokrenete program, mogući izlaz bit će:
∑ je Zbir ∫ je Integral