C ++ fwscanf () - C ++ Standardbibliotek

Funktionen fwscanf () i C ++ læser bred karakter fra filstrøm.

Funktionen fwscanf () er defineret i headerfilen.

fwscanf () prototype

 int fwscanf (FILE * stream, const wchar_t * format,…);

Funktionen fwscanf () læser dataene fra filstrømstrømmen og gemmer værdierne i de respektive variabler.

fwscanf () Parametre

  • stream: Indgangsfilstrømmen, som dataene læses fra.
  • format: Markør til en null-termineret tegnstreng, der specificerer, hvordan input skal læses. Den består af formatspecifikationer, der starter med%.
    Formatstrengen har følgende dele:
    • Ikke-mellemrumstegn undtagen%, som hver bruger et identisk tegn fra inputstrømmen. Det kan få funktionen til at mislykkes, hvis det næste tegn på streamen ikke sammenligner det samme.
    • Hvidt mellemrumstegn: Alle på hinanden følgende mellemrumstegn behandles som et enkelt mellemrumstegn. Yderligere betragtes ' n', ' t' og '' som de samme.
    • Konverteringsspecifikation: Den følger følgende format:
      • Indledende% tegn, der angiver begyndelsen
      • En valgfri * kaldet tildelingsundertrykkende karakter. Hvis dette tegn er til stede, tildeler fwscanf () ikke resultatet til noget modtagende argument.
      • Et valgfrit positivt heltal, der angiver den maksimale feltbredde. Det specificerer det maksimale antal tegn, som fwscanf () har tilladelse til at forbruge, når den konvertering er specificeret af den aktuelle konverteringsspecifikation.
      • En valgfri længdemodifikator, der angiver størrelsen på det modtagende argument.
      • En konverteringsformat specificerer.
    Formatspecifikatorer
    Format Specifier Beskrivelse
    % Matcher den bogstavelige%
    c Matcher et enkelt tegn eller flere tegn. Hvis bredde er defineret, matcher den nøjagtigt bredde.
    s Matcher på hinanden følgende ikke-mellemrumstegn. Hvis bredde er defineret, matcher den nøjagtigt bredde tegn, eller indtil første hvide mellemrum er fundet.
    (sæt) Matcher en ikke-tom række af tegn fra det givne sæt tegn. Hvis er til stede i begyndelsen af ​​sættet, matches alle de tegn, der ikke er i sættet.
    d Matcher et decimaltal.
    jeg Matcher et heltal.
    o Matcher et usigneret oktalt heltal.
    X eller x Matcher et usigneret hexadecimalt heltal.
    u Matcher et usigneret decimaltal.
    A eller a, E eller e, F eller f, G eller g Matcher et flydende nummer.
    n Returnerer antallet af læste tegn indtil videre.
    s Matcher en implementeringsdefineret tegnsekvens, der definerer en markør.

    Så det generelle format for formatspecifikator er:
     % (*) (bredde) (længde) specificator
  • …: Andre yderligere argumenter for modtagelse af data. De forekommer i en sekvens i henhold til formatspecifikatoren.

fwscanf () Returværdi

  • Funktionen fwscanf () returnerer antallet af modtagende argumenter, der er tildelt med succes.
  • Hvis der opstår fejl, før det første modtagelsesargument blev tildelt, returneres EOF.

Eksempel: Hvordan fungerer 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; )

Når du kører programmet, vil en mulig output være:

 ∑ er Summation ∫ er integreret

Interessante artikler...