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语言 字符串分割

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mytop安装,使用mytop监控MySQL性能 (总结)

    mytop安装,使用mytop监控MySQL性能 (总结)

    2021年10月29日
    39
  • autocad二次开发资料总结

    autocad二次开发资料总结autocad二次开发AutoCAD(AutoComputerAidedDesign)是美国Autodesk公司研制开发的一款计算机辅助设计软件,它不是一款简单的绘图工具,而是一个复杂的计算机辅助设计系统。我们可以根据他灵活的开放性对其进行二次开发定制,让它更加适用于某一具体的设计领域。中文名AutoCAD二次开发外文名AutoCADDevelopmentSyst

    2025年8月14日
    3
  • 使用ExecuteReader时报错“阅读器关闭时尝试调用Read无效”的解决办法

    使用ExecuteReader时报错“阅读器关闭时尝试调用Read无效”的解决办法出现如下绿色字体出错的问题,是由于using使用过后数据库会自动关闭,出了using的作用域后,在调用的时候无法找到信息form1.cs        publicstaticSqlDataReaderExecuteReader(stringsql,paramsSqlParameter[]parameters)    {      stringconnStr…

    2022年6月20日
    66
  • strictmode android,Android 应用性能优化-StrictMode(严格模式)

    strictmode android,Android 应用性能优化-StrictMode(严格模式)UI线程如果被阻塞5秒的话,那么应用程序此时就会弹出ANR的对话框,ANR对应用程序来说是一个很严重的问题。如何防止应用程序出现ANR,怎么分析查看导致ANR问题的原因?我们来介绍Android的严格模式。怎样开启严格模式有两种开启方式。开发者选项进入开发者选项,里面找到启用严格模式,打开。当应用主线程执行长时间操作的话会闪锁屏幕。StrictModeAPI(代码调用)可以在Activit…

    2022年5月25日
    38
  • 【Python秒杀脚本】淘宝或京东等秒杀抢购

    【Python秒杀脚本】淘宝或京东等秒杀抢购提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、环境二、安装1.ChromeDriver安装2.Seleuinm安装3.淘宝秒杀脚本4.京东秒杀脚本总结前言提示:这里可以添加本文要记录的大概内容:我们的目标是秒杀淘宝或京东等的订单,这里面有几个关键点,首先需要登录淘宝或京东,其次你需要准备好订单,最后要在指定时间快速提交订单。这里就要用到一个爬虫利器Selenium,Selenium是一个用于Web应用程序测试的工具,Selenium可以直接运行在浏览器中,通.

    2022年5月7日
    49
  • 飞鸽传书2011下载(飞鸽传书)

    飞鸽传书2011下载(飞鸽传书)

    2021年12月10日
    59

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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