数字的字符串处理
来源:互联网 发布:seo属于网络营销吗 编辑:程序博客网 时间:2024/05/15 10:08
在一些情况下,我们可能需要把一个字符串中的数字提取出来,这时候如果自己写函数就太麻烦了,c语言标准库中有一些弄好的函数供我们使用。
现在我们来一起学习一下吧。
1、atoi(char* buf),atof(char* buf)。
这两个函数一看名字就猜到了,前者是转换成int,后者是转换成double。
我们以atoi为例讲下它的用法。
头文件:<stdlib.h>
参数:如上所示。
函数功能:从这个地址开始直到遇到不是数字的字符终止,截取这一串数字。
返回值:将这一串数字变为int型,然后返回结果。
- int main()
- {
- int n;
- char buf[100]="123456.789";
- n = atoi(buf);
- printf("%d\n",n); //结果输出:123456
- return 0;
- }
这两个函数同样可以实现上述功能。
我们继续以前者为例讲下它的用法。
头文件:<stdio.h>
参数:如上所示,后面可以加多个参数,而且输入格式也可以根据需要改变。
函数功能:从这个地址开始直到遇到不是数字的字符终止,截取这一串数字,并将结果直接赋给n。
返回值:成功返回参数的数目,失败返回0。
- int main()
- {
- int n;
- char buf[100]="123456.789";
- sscanf(buf,"%d",&n);
- printf("%d\n",n); //结果输出:123456
- return 0;
- }
那么,如何将一个数字转换成字符串呢?
有一个函数和sscanf相对应,那就是sprintf(buf,"%d",n)。
头文件:<stdio.h>
参数:如上所示,后面可以加多个参数,而且输入格式也可以根据需要改变。
函数功能:把数字n以某种格式写入字符串buf。
返回值:应该和printf类似吧。不太清楚。
- int main()
- {
- int n=123456;
- sprintf(buf,"%d",n);
- printf("%s\n",buf); //结果输出:123456
- return 0;
- }
另外,sscanf(char* buf,"%[ ]",char* p)还可以来按某种格式分离字符串。
其中第二个参数中的"%[ ]"代表集合操作。
%[a-z] 表示匹配 a 到 z 中任意字符
%[aB'] 表示匹配 a、B、' 中一员的字符
%[^a-z] 表示匹配非 a 到 z 的任意字符
%[^aB'] 表示匹配非 a、B、‘ 的任意字符
比如下面的代码,可以将一个等式的各个加数分离出来。
- int main()
- {
- char buf[]="123+456+789+000=",p[111];
- int n,len=0;
- while(buf[len]!='\0')
- {
- sscanf(buf+len,"%[0-9]",p); //表示取遇到不是0到9为止的字符串
- // sscanf(buf+len,"%[^+=]",p); //表示取遇到+、=为止的字符串
- len += strlen(p)+1;
- puts(p);
- }
- getch();
- return 0;
- }
而且,[^ ]与[ ]不能一起使用,就是说一个[ ]中如果第一个位置出现 ^ ,则它只能代表匹配非XX的字符;如果 ^ 没有出现在第一个位置,则表示它只是代表 ’^‘ 这个字符。
另外,[ ]中, - 与单个字符可以混合使用,比如 %[a-z+] 表示匹配 a 到 z 和 + 中的任意字符,%[^a-z+] 表示匹配非 a 到 z 和 + 中的任意字符。
转载地址:http://blog.csdn.net/dgq8211/article/details/7580971
- 数字的字符串处理
- 数字的字符串处理
- 数字的字符串处理
- 数字的字符串处理
- 数字的字符串处理
- 处理数字加小数点的字符串
- JavaScript字符串与数字的特殊处理
- 字符串+数字 ---- 重新组成新的字符串的处理程序
- 1048. 数字加密(字符串处理)
- Bash支持的一系列数字和字符串处理操作
- 16-判断输入的是否是数字(字符串处理)
- Fortran中处理字符串数字和文件的模块StrNum
- 发现了两个有关数字字符串的处理函数
- cpp:处理字符串与数字的混合输入(动态数组)
- shell的字符串和数字的转化(数字自动做字符串处理,变量名做字符串输出用单引号)
- 数字字符串的解析
- 字符串数字的提取
- 数字字符串的基数排序
- DOS下 目录含空格
- 各种排序算法(2)
- 链表面试题
- CKEditor+CKFinder屏蔽/开启“浏览服务器”按钮
- Hadoop使用常见问题以及解决方法
- 数字的字符串处理
- mtk动态添加菜单
- decorator模式---C++
- 分析Hadoop自带WordCount例子的执行过程(1)
- 网站分析中常见的流量变化原因
- 第11章 委托、事件和Lambda
- Struts2 文件上传
- java编写的基于TCP协议的聊天室
- 如何将GridView中的数据导入到数据库