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 <stdio.h>
#include <stdlib.h>
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<stdio.h>
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][h]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 <stdio.h>
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<stdio.h>
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 <stdio.h>
#include <stdlib.h>
int main()
{
char str[10]={0,};
snprintf(str, sizeof(str), "%s", "0123456789012345678");
printf("str=%s/n", str);
return 0;
}
//在使用过程中尽量使用snprintf代替sprintf