C语言 字符串分割

C语言 字符串分割C语言字符串分割一、简述记–字符串分割,strtok()函数的使用例子、自己实现split()函数。二、例子代码#include<stdio.h>#include<string.h>/**函数:split*描述:按指定分隔符分割字符串*参数:* str:要分割的字符串* strLen:要分割…

大家好,又见面了,我是你们的朋友全栈君。

                                                         C语言 字符串分割

 

一、简述
        记–字符串分割,strtok()函数的使用例子、自己简单实现split()函数。

二、例子代码

#include <stdio.h>
#include <string.h>
 
/*
 * 函数:split
 * 描述:按指定分隔符分割字符串
 * 参数:
 *		str:要分割的字符串
 *		strLen:要分割的字符串的长度
 * 		splitChar:分隔符
 * 		index:获取第几部分, 1<=index
 *		result:结果字符串, result = str[index-1];
 * 		maxLen:指定结果的最大长度
 * 返回值:
 *		>=0:成功, 结果长度
 * 		其它:失败
 * 例子:
 *		split("11;22;33", 8, ';', 2, result. 16);
 *		结果result是:22.
 */
int split(const char* str, int strLen, const char* splitChar, int index, char* result, int maxLen)
{
	int i = 0;
    int ret = 0;	
	int findLen = 0;
	int findFlag = 0;	
	int startIndex = 0;
	int splitCharLen = 0;
	
	//合法性判断
	if(NULL == str || NULL == result || NULL == splitChar || index<=0)
	{
		return -1;
	}		
	splitCharLen = strlen(splitChar);
	findLen = strLen-splitCharLen;
	if(findLen<0)
	{
		return -2;
	}	
	
	//查找结果的左右分隔符位置
	for(; i<=findLen && str[i] != '\0'; i++)
	{
		if(strncmp(&str[i], splitChar, splitCharLen) == 0)
		{
			if(0 == findFlag)//find the left
			{
				startIndex++;
				if(1 == index)//第一个直接返回
				{
					strncpy(result, &str[0], i);
					ret = i;
					break;
				}
				else if(startIndex+1 == index)
				{
					startIndex = i;
					findFlag = 1;
				}
			}
			else//find the right
			{
				findFlag = 2;
				break;
			}
		}
	}	
	
	//截取结果
	if(0 != findFlag && startIndex<strLen-1)
	{
		startIndex += splitCharLen;
		ret = i-startIndex;//结果的字符个数
		if(ret>maxLen || ret>strLen)
		{
			ret = 0;
		}
		else if(ret>0)
		{
			strncpy(result, &str[startIndex], ret);
			ret = strlen(result);
		}
	}
	return ret;
}
 
int main(void)
{	
	{
		const char* splitChar = ";";
		printf("\n==========strtok1==========\n");
		char str1[128] = "Keep;learning;and;study;hard";
		printf("str1:\"%s\", splitChar:\"%s\"\n", str1, splitChar);
		
		char* ptr = strtok(str1, splitChar);
		for(; ptr != NULL; )
		{
			printf("%s\n", ptr);
			ptr = strtok(NULL, splitChar);
		}
		printf("strtok after, str1:%s\n", str1);
		
		printf("\n==========split1==========\n");
		char str2[128] = "Keep;learning;and;study;hard";
		printf("str2:\"%s\", splitChar:\"%s\"\n", str2, splitChar);
		int i;
		int ret = 1;
		char result[128];
		int strLen = strlen(str2);
		int resultLen = sizeof(result);
		for(i=1; ret>0; i++)
		{
			memset(result, 0, sizeof(result));
			ret = split(str2, strLen, splitChar, i, result, resultLen);
			if(ret>0)
			{
				printf("%s\n", result);
			}
		}
		printf("split after, str2:%s\n", str2);
	}
	
	{
		const char* splitChar = "##";
		printf("\n==========strtok2==========\n");
		char str1[128] = "Keep##learning##and##study##hard";
		printf("str1:\"%s\", splitChar:\"%s\"\n", str1, splitChar);
		
		char* ptr = strtok(str1, splitChar);
		for(; ptr != NULL; )
		{
			printf("%s\n", ptr);
			ptr = strtok(NULL, splitChar);
		}
		printf("strtok after, str1:%s\n", str1);
		
		printf("\n==========split2==========\n");
		char str2[128] = "Keep##learning##and##study##hard";
		printf("str2:\"%s\", splitChar:\"%s\"\n", str2, splitChar);
		int i;
		int ret = 1;
		char result[128];
		int strLen = strlen(str2);
		int resultLen = sizeof(result);
		for(i=1; ret>0; i++)
		{
			memset(result, 0, sizeof(result));
			ret = split(str2, strLen, splitChar, i, result, resultLen);
			if(ret>0)
			{
				printf("%s\n", result);
			}
		}
		printf("split after, str2:%s\n", str2);
	}
	return 0;
}

三、测试结果

C语言 字符串分割

 

C语言 字符串分割

四、总结
    strtok()函数介绍

 

strtok()函数
功能 分割字符串
头文件 #include <string.h>
原型 char *strtok(char *str, const char *delim);
参数

str:要分割的字符串

delim:分隔符

返回值 成功:非空指针,分割后的结果字符串
失败:NULL,分割后没有得到有效的字符串
备注

第一次调用strtok()时,要解析的字符串应在str中指定。 在每个随后的应解析相同字符串的调用中,str必须置空。

即第一次是strtok(str, spplitChar);

后面调用strtok(NULL, spplitChar);

注意:调用strtok之后会修改原来的str

 

 

详情请查询man手册,man strtok

C语言 字符串分割

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/133071.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • java怎么求数组的和_java求和函数写法

    java怎么求数组的和_java求和函数写法Java经典题目之一,数组的各种求和,今天小编就用一些例子带大家了解一下其中详情。基础求和#includeusingnamespacestd;//数组求和//方法一:时间复杂度为O(n),额外空间为(n)intArraySum(intarr[],intn){intsum=0;for(inti=0;i{sum+=arr[i];}returnsum;}//方法二…

  • mybatis返回值为map类型时怎么处理_构造函数不能有返回类型

    mybatis返回值为map类型时怎么处理_构造函数不能有返回类型最有用到mybatis返回一个map结果集,然后就针对性的在网上找了一些相关大牛的总结:1.mybatis返回map结果集-红尘中人·杨哥-博客园2.MyBatis返回Map|码农网然后经过自己的测试终于可以应用实际业务中1、如果你确定返回的数据只有一条,你可以这样整xml中:<selectid=”searchncomedateByInvestID”resultMap=”java.util.HashMap”>selectt1.invest.

  • linux 查看文件系统类型「建议收藏」

    linux 查看文件系统类型「建议收藏」查看linux文件系统的方式有多种,一般通用的就mount和df。具体如下:目录mountdffileparted mount df file parted

  • Android Studio Unable to find EOCD signature解决方法

    Android Studio Unable to find EOCD signature解决方法今天早上来公司突然发现项目打包不了研究了一下应该是gradle版本冲突了解决方法就是Build

  • 居民身份证号码组成规则

    居民身份证号码组成规则第一、二位表示省(自治区、直辖市、特别行政区)。第三、四位表示市(地级市、自治州、地区、盟及直辖市所属区和县的汇总码)。其中,01-20,51-70表示地级市;21-50表示地区(自治州、盟)。第

  • ExecuteReader报错,语法错误

    ExecuteReader报错,语法错误先上图:随后我就死命的看自己的sql语句,可是看来看去,也看不出问题,明明是很对的。。。最后,到处查找解决方案,终于在论坛见到了大神的一句:“你输入的是中文字符的空格!”然后我赶紧回来一看,果然是。。。。。。瞬间蛋碎了一地。。。。sql语句莫名报语法错误的时候,赶紧仔细检查下时候是空格问题,这个问题很难发现!!!!!

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号