解析C语言中常用的格式化输入、输出函数

fprintf(格式化输出数据至文件)
这个函数的功能类似于文件操作函数 fwrite();通过一个文件描述符将数据写入该文件描述符所指向的文件中。

函数定义:

  • int fprintf(FILE * stream, const char * format,…….);

函数说明 :

  • fprintf()会根据参数format字符串来转换并格式化数据,然后将结果输出到参数stream指定的文件中,直到出现字符串结束(‘\0’)为止。

返回值 :

  • 关于参数format字符串的格式请参考printf()。成功则返回实际输出的字符数,失败则返回-1,错误原因存于errno中。

fscanf(格式化字符串输入)
这个函数的功能类似于文件操作函数fread();通过一个文件描述符将数据读入到缓冲区中。

函数定义:

  • int fscanf(FILE * stream ,const char *format,….);

函数说明:

  • fscanf()会自参数stream的文件流中读取字符串,再根据参数format字符串来转换并格式化数据。格式转换形式请参考scanf()。转换后的结构存于对应的参数内。

返回值:

  • 成功则返回参数数目,失败则返回-1,错误原因存于errno中。

实例:

#include   
#include   
int main(int argc, char **argv)  
{  
    char a_buff[128], b_buff[128];  
    FILE *fp = NULL;  
    fp = fopen("main.c", "w+")
    if(fp == NULL)
    {  
        printf("error...\n");  
        return -1;  
    }  
    printf("input a string(<128):");  
    scanf("%s", a_buff);  
    fprintf(fp, "%s", a_buff); //fwrite(a_buff, strlen(a_buff), 1, fd); 

    fseek(fp, 0, SEEK_SET); // 意义和rewind(fp);相同  

    fscanf(fp, "%s", b_buff); // fread(b_buff, strlen(b_buff), 1, fd);
    printf("%s\n", b_buff);  
    fclose(fp);  
    return 0;  
} 
//上面的例子是先将数据写入a_buff[]这个缓冲区中,然后再由fprintf()函数将其写入文件中,
//再通过fscanf()函数将文件中的数据读入b_buff[]缓冲区中。

printf(格式化输出数据)

函数定义:

  • int printf(const char * format,………….);

函数说明:

  • printf()会根据参数format字符串来转换并格式化数据,然后将结果写出到标准输出设备,直到出现字符串结束(‘\0’)为止。参数format字符串可包含下列三种字符类型:
    一般文本,伴随直接输出。
    ASCII控制字符,如\t、\n等。
    格式转换字符。格式转换为一个百分比符号(%)及其后的格式字符所组成。一般而言,每个%符号在其后都必需有一printf()的参数与之相呼应(只有当%%转换字符出现时会直接输出%字符),而欲输出的数据类型必须与其相对应的转换字符类型相同。

printf()格式转换的一般形式如下:

  • %(flags)(width)(.prec)type //以括号括起来的参数为选择性参数,而%与type则是必要的。

介绍type的几种形式:

  • 整数:
    %d 整数的参数会被转成一有符号的十进制数字
    %u 整数的参数会被转成一无符号的十进制数字
    %o 整数的参数会被转成一无符号的八进制数字
    %x 整数的参数会被转成一无符号的十六进制数字,并以小写abcdef表示
    %X 整数的参数会被转成一无符号的十六进制数字,并以大写ABCDEF表示

  • 浮点型数:
    %f double 型的参数会被转成十进制数字,并取到小数点以下六位,四舍五入。
    %e double型的参数以指数形式打印,有一个数字会在小数点前,六位数字在小数点后,而在指数部分会以小写的e来表示。
    %E 与%e作用相同,唯一区别是指数部分将以大写的E 来表示。
    %g double 型的参数会自动选择以%f 或%e 的格式来打印,其标准是根据欲打印的数值及所设置的有效位数来决定。
    %G 与%g 作用相同,唯一区别在以指数形态打印时会选择%E格式。

  • 字符及字符串:
    %c 整型数的参数会被转成unsigned char型打印出。
    %s 指向字符串的参数(指针)会被逐字输出,直到出现NULL字符为止
    %p 如果是参数是“void *”型指针则使用十六进制格式显示。

    prec 有以下几种情况

    • 正整数的最小位数。
    • 在浮点型数中代表小数位数。
    • 在%g 格式代表有效位数的最大值。
    • 在%s格式代表字符串的最大长度。

    width为参数的最小长度,若此栏并非数值,而是*符号,则表示以下一个参数当做参数长度。
    flags 有下列几种情况:

    • 一般在打印负数时,printf()会加印一个负号,整数则不加任何负号。此旗标会使得在打印正数前多一个正号(+)。
      #此旗标会根据其后转换字符的不同而有不同含义。当在类型为o 之前(如%#o),则会在打印八进制数值前多印一个o。而在类型为x 之前(%#x)则会在打印十六进制数前多印’0x’,在型态为e、E、f、g或G 之前则会强迫数值打印小数点。在类型为g 或G之前时则同时保留小数点及小数位数末尾的零。

    • 0 当有指定参数时,无数字的参数将补上0。默认是关闭此旗标,所以一般会打印出空白字符。

返回值:

  • 成功则返回实际输出的字符数,失败则返回-1,错误原因存于errno中。

实例:

#include  
int main()  
{  
    int i = 150;  
    int j = -100;  
    double k = 3.14159;  
    printf(“%d %d %f\n”I, j, k);  
    printf(“%5d %*d\n”, i, 5, i);   /* 参数5会代入格式*中,而与%5d同意义 */ 
    return 0; 
}  

//执行结果:

150 -100 3.141590
150 150 四

sacnf(格式化字符串输入)

函数定义:

  • int scanf(const char * format,…….);

函数说明:

  • scanf()会将输入的数据根据参数format字符串来转换并格式化数据。Scanf()格式转换的一般形式如下:
    • %[*][size][l][h]type
      以中括号括起来的参数为选择性参数,而%与type则是必要的。

选择性参数:

    • 代表该对应的参数数据忽略不保存。
  • size 为允许参数输入的数据长度。
  • l 输入的数据数值以long int 或double型保存。
  • h 输入的数据数值以short int 型保存。
  • type的几种形式:

    • %d 输入的数据会被转成一有符号的十进制数字(int)。
    • %i 输入的数据会被转成一有符号的十进制数字,若输入数据以“0x”或“0X”开头代表转换十六进制数字,若以“0”开头则转换八进制数字,其他情况代表十进制。
    • %0 输入的数据会被转换成一无符号的八进制数字。
    • %u 输入的数据会被转换成一无符号的正整数。
    • %x 输入的数据为无符号的十六进制数字,转换后存于unsigned int型变量。
    • %X 同%x
    • %f 输入的数据为有符号的浮点型数,转换后存于float型变量。
    • %e 同%f
    • %E 同%f
    • %g 同%f
    • %s 输入数据为以空格字符为终止的字符串。
    • %c 输入数据为单一字符。
    • [] 读取数据但只允许括号内的字符。如[a-z]。
    • [^] 读取数据但不允许中括号的^符号后的字符出现,如[^0-9].

返回值:

  • 成功则返回参数数目,失败则返回-1,错误原因存于errno中。

实例:

#include   
int main()  
{  
    int i;  
    unsigned int j;  
    char s[5];  
    scanf(“%d %x %5[a-z] %*s %f”,&i,&j,s,s);  
    printf(“%d %d %s\n”, i, j, s);  
    return 0;
}  
//执行结果: 

0 0x1b aaaaaaaaaa bbbbbbbbbb
10 27 aaaaa

sprintf(格式化字符串复制)
将数据以特定的格式写入一块内存中或缓冲区中。

函数定义:

  • int sprintf( char str, const char format,………);

函数说明:

  • sprintf()会根据参数format字符串来转换并格式化数据,然后将结果复制到参数str所指的字符串数组,直到出现字符串结束(’\0’)为止。关于参数format字符串的格式请参考printf()。

返回值:

  • 成功则返回参数str字符串长度,失败则返回-1,错误原因存于errno中。
    附加说明:使用此函数得留意堆栈溢出,或改用snprintf()

sscanf(格式化字符串输入)
将内存或缓冲区中的数据以特定的形式读出

函数定义:

  • int sscanf (const char str, const char format,……..);

函数说明:

  • sscanf()会将参数str的字符串根据参数format字符串来转换并格式化数据。格式转换形式请参考scanf()。转换后的结果存于对应的参数内。

返回值 :

  • 成功则返回参数数目,失败则返回-1,错误原因存于errno中。

实例:

#include  
int main()  
{  
    int a = 100;  
    char buff[10];  
    sprintf(buff, "%s", a);
    int b = 0;
    printf("buff = %s\n", buff);
    sscanf(buff, "%d", &b);  
    printf(“b = %d”, b);  
}  
//执行结果  b = 100;

snprintf的用法
函数定义

  • int snprintf(char restrict buf, size_t n, const char restrict format, …);

函数说明:

  • 最多从源串中拷贝n-1个字符到目标串中,然后再在后面加一个0。所以如果目标串的大小为n的话,将不会溢出。

函数返回值:

  • 若成功则返回欲写入的字符串长度,若出错则返回负值。
#include 
#include 
int main()
{
     char str[10]={0,};
     snprintf(str, sizeof(str), "%s", "0123456789012345678");
     printf("str=%s/n", str);
     return 0;
}
//在使用过程中尽量使用snprintf代替sprintf

你可能感兴趣的:(c)