C ++: n fwscanf () -toiminto lukee leveän merkin tiedostovirrasta.
Fwscanf () -toiminto määritetään otsikkotiedostossa.
fwscanf () -prototyyppi
int fwscanf (FILE * virta, const wchar_t * muoto,…);
Fwscanf () -toiminto lukee tiedot tiedostovirrasta ja tallentaa arvot vastaaviin muuttujiin.
fwscanf () -parametrit
- virta: Tulotiedostovirta, josta tiedot voidaan lukea.
- muoto: Osoitin nollapäätteiseen merkkijonoon, joka määrittää, miten syötettä luetaan. Se koostuu muotomäärittimistä, jotka alkavat%: lla.
Formaatin merkkijonossa on seuraavat osat:- Muut kuin välilyönnit, paitsi%, joista kukin kuluttaa yhden identtisen merkin syöttövirrasta. Se voi aiheuttaa funktion epäonnistumisen, jos virran seuraava merkki ei ole yhtä suuri.
- Välilyönti-merkki: Kaikki peräkkäiset tyhjät-merkit käsitellään yhtenä tyhjänä -merkkinä. Lisäksi ' n', ' t' ja '' pidetään samoina.
- Muunnosmäärittely: Se noudattaa seuraavaa muotoa:
- Alkuperäinen% merkki, joka määrittää alun
- Valinnainen * nimeltään tehtävää tukahduttava merkki. Jos tämä merkki on läsnä, fwscanf () ei lisää tulosta mihinkään vastaanottavaan argumenttiin.
- Valinnainen positiivinen kokonaisluku, joka määrittää kentän enimmäisleveyden. Se määrittää merkkien enimmäismäärän, jonka fwscanf () saa kuluttaa tehdessään nykyisen muunnosmäärityksen mukaisen muunnoksen.
- Valinnainen pituusmuunnin, joka määrittää vastaanottavan argumentin koon.
- Muunnosmuodon määrittelijä.
Formaatin määrittelijä Kuvaus % Vastaa kirjaimellista% c Yhdistää yhden merkin tai useita merkkejä. Jos leveys on määritetty, vastaa täsmälleen leveysmerkkejä. s Vastaavat peräkkäisiä muita kuin välilyöntejä. Jos leveys on määritelty, vastaa täsmälleen leveysmerkkejä tai kunnes ensimmäinen välilyönti löytyy. (aseta) Vastaa ei-tyhjää merkkijonoa annetusta merkistöstä. Jos on joukon alussa, kaikki merkit, joita ei ole asetettu, vastaavat toisiaan. d Vastaa desimaalilukua. i Vastaa kokonaislukua. o Vastaa allekirjoittamatonta oktaalilukua. X tai x Vastaa allekirjoittamatonta heksadesimaalilukua. u Vastaa allekirjoittamatonta desimaalilukua. A tai a, E tai e, F tai f, G tai g Vastaa liukuluvun lukua. n Palauttaa tähän mennessä luettujen merkkien lukumäärän. s Vastaa toteutuksen määrittelemää merkkijonoa, joka määrittää osoittimen.
Joten muodon määrittelijän yleinen muoto on:% (*) (leveys) (pituus) määrittelijä
- …: Muita lisäväitteitä tietojen vastaanottamiseksi. Ne esiintyvät järjestyksessä muodon määrittelijän mukaan.
fwscanf () Palautusarvo
- Fwscanf () -funktio palauttaa onnistuneesti määritettyjen vastaanottavien argumenttien määrän.
- Jos vika tapahtuu ennen kuin ensimmäinen vastaanottava argumentti on osoitettu, EOF palautetaan.
Esimerkki: Kuinka fwscanf () -toiminto toimii?
#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; )
Kun suoritat ohjelmaa, mahdollinen tulos on:
∑ on yhteenveto ∫ on integraali