C ++ fwscanf () - Biblioteca estándar de C ++

La función fwscanf () en C ++ lee caracteres anchos de la secuencia de archivos.

La función fwscanf () se define en el archivo de encabezado.

prototipo de fwscanf ()

 int fwscanf (ARCHIVO * flujo, const wchar_t * formato,…);

La función fwscanf () lee los datos del flujo de archivos y almacena los valores en las variables respectivas.

Parámetros de fwscanf ()

  • flujo: el flujo del archivo de entrada para leer los datos.
  • formato: puntero a una cadena de caracteres terminada en nulo que especifica cómo leer la entrada. Consiste en especificadores de formato que comienzan con%.
    La cadena de formato tiene las siguientes partes:
    • Caracteres que no son espacios en blanco, excepto%, cada uno de los cuales consume un carácter idéntico del flujo de entrada. Puede hacer que la función falle si el siguiente carácter de la secuencia no se compara igual.
    • Carácter de espacio en blanco: todos los caracteres de espacio en blanco consecutivos se tratan como un solo carácter de espacio en blanco. Además, ' n', ' t' y '' se consideran iguales.
    • Especificación de conversión: Sigue el siguiente formato:
      • Carácter% inicial que especifica el comienzo
      • Un carácter opcional * llamado supresor de asignaciones. Si este carácter está presente, fwscanf () no asigna el resultado a ningún argumento receptor.
      • Un número entero positivo opcional que especifica el ancho máximo de campo. Especifica el número máximo de caracteres que fwscanf () puede consumir al realizar la conversión especificada por la especificación de conversión actual.
      • Un modificador de longitud opcional que especifica el tamaño del argumento de recepción.
      • Un especificador de formato de conversión.
    Especificadores de formato
    Especificador de formato Descripción
    % Coincide con el% literal
    C Coincide con un solo carácter o varios caracteres. Si se define el ancho, coincide exactamente con los caracteres de ancho.
    s Coincide con caracteres consecutivos sin espacios en blanco. Si se define el ancho, coincide exactamente con los caracteres de ancho o hasta que se encuentre el primer espacio en blanco.
    (conjunto) Coincide con una secuencia de caracteres no vacía del conjunto de caracteres dado. Si está presente al principio del conjunto, entonces todos los caracteres que no están en el conjunto coinciden.
    re Coincide con un entero decimal.
    yo Coincide con un número entero.
    o Coincide con un entero octal sin signo.
    X o x Coincide con un entero hexadecimal sin signo.
    tu Coincide con un entero decimal sin signo.
    A o a, E o e, F o f, G o g Coincide con un número de punto flotante.
    norte Devuelve el número de caracteres leídos hasta ahora.
    pags Coincide con una secuencia de caracteres definida por la implementación que define un puntero.

    Entonces, el formato general del especificador de formato es:
     % (*) (ancho) (largo) especificador
  • …: Otros argumentos adicionales para recibir datos. Ocurren en una secuencia de acuerdo con el especificador de formato.

fwscanf () Valor de retorno

  • La función fwscanf () devuelve el número de argumentos recibidos asignados correctamente.
  • Si se produce un error antes de que se asignara el primer argumento de recepción, se devuelve EOF.

Ejemplo: ¿Cómo funciona la función 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; )

Cuando ejecute el programa, una posible salida será:

 ∑ es la suma ∫ es integral

Articulos interesantes...