【C/C++】之 strtok,strstr,sscanf 解析字符串

来源:互联网 发布:淘宝悬浮框生成器 编辑:程序博客网 时间:2024/06/03 19:13

C/C++之 strtok,strstr,sscanf 解析字符串

一.sscanf() - 从一个字符串中读进与指定格式相符的数据。

函数原型:
int sscanf( const char *, const char *, ...);
int sscanf(const char *buffer,const char *format,[argument ]...);
buffer存储的数据
format格式控制字符串
argument 选择性设定字符串
sscanf会从buffer里读进数据,依照format的格式将数据写入到argument里。



示例:
sscanf("123-456*abc\ndedf","%d-%d*%s\n%s",int1,int2,buf3,buf4);

二.strtok(buffer, strDelimit); 

分解字符串为一组字符串。s为要分解的字符串,delim为分隔符字符串。首次调用时,s指向要分解的字符串,之后再次调用要把s设成NULL。

#include <stdio.h>#include <stdlib.h>#include <string.h>int main(){  char str[]="ab,cd,ef"; char *ptr; printf("before strtok:  str=%s\n",str); printf("begin:\n");ptr = strtok(str, ",");  while(ptr != NULL){      printf("str=%s\n",str);       printf("ptr=%s\n",ptr);       ptr = strtok(NULL, ",");   }   system("pause");   return 0;}

三.strchr

函数原型:extern char *strchr(const char *s,char c);查找字符串s中首次出现字符c的位置。

四.strstr

strstr() 函数搜索一个字符串在另一个字符串中的第一次出现。找到所搜索的字符串,则该函数返回第一次匹配的字符串的地址;如果未找到所搜索的字符串,则返回NULL。

函数原型:extern char *strstr(char *haystack, char *needle);
        
 用法:#include <string.h>   
 功能:从字符串haystack中寻找needle第一次出现的位置(不比较结束符NULL)。   
 说明:返回指向第一次出现needle位置的指针,如果没找到则返回NULL.
使用示例:

#include <string.h>#include <stdio.h> int main(int argc,char **argv){ char a[]="aaa||a||bbb||c||ee||"; char *needle="||";  char *haystack=a;//不能直接char *haystack="aaa||a||bbb||c||ee||"; 会报内存不能写错误 char* buf = strstr( haystack, needle); while( buf != NULL ){  buf[0]='\0';//在出现分隔符的位置设置结束符\0  printf( "%s\n", haystack);  haystack = buf + strlen(needle);    buf = strstr( haystack, needle); }  return 0;}
OUT 值:
aaa
a
bbb
c
ee


这个主要用来解决字符串匹配等问题,也可以解决网络通信中出现的粘包问题。





























0 0
原创粉丝点击