C ++ vfwscanf () - C ++ standartinė biblioteka

Funkcija vfwscanf () C ++ naudojama plačių simbolių eilutei nuskaityti iš failų srauto.

Funkcija vfwscanf () yra apibrėžta antraštės faile.

vfwscanf () prototipas

 int vfwscanf (FILE * stream, const wchar_t * format, va_list vlist);

Funkcija „vfwscanf ()“ nuskaito duomenis iš failų srauto ir išsaugo reikšmes atitinkamose vietose, kaip apibrėžta „vlist“.

vfwscanf () parametrai

  • srautas: įvesties failų srautas, iš kurio galima nuskaityti duomenis.
  • formatas: žymeklis nulinės galinės plačios simbolių eilutės, nurodančios, kaip skaityti įvestį. Jį sudaro formato specifikatoriai, prasidedantys%.
    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, „vfwscanf“ () nepriskiria rezultato jokiam priėmimo argumentui.
      • Pasirenkamas teigiamas sveikasis skaičius, nurodantis maksimalų lauko plotį. Jis nurodo maksimalų simbolių skaičių, kurį „vfwscanf“ () leidžiama sunaudoti atliekant konversiją, nurodytą dabartinėje konversijos specifikacijoje.
      • Pasirenkamas ilgio modifikatorius, nurodantis gaunamo argumento dydį.
      • Konversijos formato specifikatorius.
    Formato specifikatoriai
    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.

vfwscanf () Grąžinimo vertė

  • Jei pavyks, funkcija vfwscanf () grąžins sėkmingai perskaitytų argumentų skaičių.
  • Sugedus, EOF grąžinamas.

Pavyzdys: Kaip veikia funkcija vfwscanf ()?

 #include #include #include #include void read( FILE *fp, const wchar_t* format,… ) ( va_list args; va_start (args, format); vfwscanf (fp, format, args); va_end (args); ) int main () ( setlocale(LC_ALL, "en_US.UTF-8"); wchar_t symbol() = L"u0915u0916u0917u0918u0919"; wchar_t names(5)(5) = (L"Ka", L"Kha", L"Ga", L"Gha", L"Nga"); FILE *fp = fopen("example.txt","w+"); for (int i=0; i<5; i++) fwprintf(fp, L"%lc %ls ", symbol(i), names(i)); rewind(fp); wchar_t ch, str(5); for (int i=0; i<5; i++) ( read(fp, L"%lc %ls ", &ch, str); wprintf(L"%lc - %ls", ch, str); ) fclose(fp); return 0; )

Kai paleisite programą, galimas rezultatas bus:

 क - Ka ख - Kha ग - Ga घ - Gha ङ - Nga

Įdomios straipsniai...