c++语言截取字符串,详解C++ string常用截取字符串方法

c++语言截取字符串,详解C++ string常用截取字符串方法string常用截取字符串方法有很多,但是配合使用以下两种,基本都能满足要求:find(stringstrSub,npos);find_last_of(stringstrSub,npos);其中strSub是需要寻找的子字符串,npos为查找起始位置。找到返回子字符串首次出现的位置,否则返回-1;注:(1)find_last_of的npos为从末尾开始寻找的位置。(2)下文中用到的strs…

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

string常用截取字符串方法有很多,但是配合使用以下两种,基本都能满足要求:

find(string strSub, npos);

find_last_of(string strSub, npos);

其中strSub是需要寻找的子字符串,npos为查找起始位置。找到返回子字符串首次出现的位置,否则返回-1;

注:

(1)find_last_of的npos为从末尾开始寻找的位置。

(2)下文中用到的strsub(npos,size)函数,其中npos为开始位置,size为截取大小

例1:直接查找字符串中是否具有某个字符串(返回”2″)

std::string strPath = “E:\\数据\\2018\\2000坐标系\\a.shp”

int a = 0;

if (strPath.find(“2018”) == std::string::npos)

{

a = 1;

}

else

{

a = 2;

}

return a;

例2:查找某个字符串的字符串(返回“E:”)

std::string strPath = “E:\\数据\\2018\\2000坐标系\\a.shp”

int nPos = strPath.find(“\\”);

if(nPos != -1)

{

strPath = strPath.substr(0, nPos);

}

return strPath;

例3:查找某个字符串中某两个子字符串之间的字符串(返回“2000坐标系”)

std::string strPath = “E:\\数据\\2018\\2000坐标系\\a.shp”

std::string::size_type nPos1 = std::string::npos;

std::string::size_type nPos2 = std::string::npos;

nPos1 = strPath.find_last_of(“\\”);

nPos2 = strPath.find_last_of(“\\”, nPos1 – 1);

if(nPos1 !=-1 && npos2 != -1)

{

strPath = strPath.substr(nPos2 + 1, nPos1 – nPos2 – 1);

}

return strPath;

提高:递归获取路径名中的子目录

//获取路径名中的子目录:strPath为路径名,strSubPath为输出的子目录,

nSearch为从尾向前检索的级别(默认为1级)

bool _GetSubPath(std::string& strPath,std::string& strSubPath, int nSearch)

{

if (-1 == nSearch || strPath.empty())

return false;

std::string::size_type nPos1 = std::string::npos;

nPos1 = strPath.find_last_of(“\\”);

if (nPos1 != -1)

{

strSubPath = strPath.substr(nPos1 + 1, strPath.length() – nPos1);

int nNewSearch = nSearch > 1 ? nSearch – 1 : -1;

_GetSubPath(strPath.substr(0, nPos1), strSubPath, nNewSearch);

}

return true;

}

int main()

{

std::string strPath = “E:\\数据\\2018\\2000坐标系\\a.shp”;

std::string strSubPath = “”;

if(_GetSubPath(strPath, strSubPath, 1)

{

printf(“返回’a.shp’”);

}

if(_GetSubPath(strPath, strSubPath, 2)

{

printf(“返回’2000坐标系’”);

}

}

以上所述是小编给大家介绍的C++ string常用截取字符串方法详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

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

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

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


相关推荐

  • Java 之 Serializable 序列化和反序列化的概念,作用的通俗易懂的解释[通俗易懂]

    Java 之 Serializable 序列化和反序列化的概念,作用的通俗易懂的解释[通俗易懂]遇到这个JavaSerializable序列化这个接口,我们可能会有如下的问题a,什么叫序列化和反序列化b,作用。为啥要实现这个Serializable接口,也就是为啥要序列化c,serialVersionUID这个的值到底是在怎么设置的,有什么用。有的是1L,有的是一长串数字,迷惑ing。我刚刚见到这个关键字Serializable的时候,就有如上的这么些问题。在处理这个…

    2022年10月23日
    0
  • 程序电脑VS2008 应用程序配置不正确,未能启动该应用程序。重新安装程序可以修复此问题。解决方法…

    程序电脑VS2008 应用程序配置不正确,未能启动该应用程序。重新安装程序可以修复此问题。解决方法…

    2021年8月24日
    56
  • java map 二维数组_Java二维数组实现简单Map

    java map 二维数组_Java二维数组实现简单Map这些天频繁的在使用二维数组,让我觉得二维数组要比Map更灵活多变,以前和别人提起“数据结构”总能听到有人问:“如果编程语言里没有HashMap,你能自己实现一个Map来用么?”。熟练了二维数组,今天我就来尝试实现一个最简单的Map吧,我没有参考网上的例子,也没去想数据结构书中是怎么讲的,纯粹的自己个一个设计方案,中途遇到很多问题,但还是逐个解决了,还有很多不足之处,希望大家能帮我指点指点,一起交流…

    2022年5月24日
    41
  • 大数据建模步骤有哪些

    大数据建模步骤有哪些  数据建模,通俗地说,就是通过建立数据科学模型的手段解决现实问题的过程。数据建模也可以称为数据科学项目的过程,并且这个过程是周期性循环的,也是是我们在做数据分析的时候会经常使用的一种数据分析方法,那么大数据建模都有哪些步骤。  1)数据测量  数据测量包括ECU内部数据获取,车内总线数据获取以及模拟量数据获取,特别是对于新能源汽车电机、逆变器和整流器等设备频率高达100KHz的信号测量,ETAS提供完整的解决方案。  2)大数据管理与分析  目前的汽车嵌入式控制系统…

    2022年4月30日
    116
  • chip seq实验原理及步骤_思科真机实验环境搭建

    chip seq实验原理及步骤_思科真机实验环境搭建实验内容通过实验环境学习了解SR-PCE。xrv_7作为PCE,计算PE1到PE2的路径。网络中IP设置,metric值与之前的实验一致。拓扑图配置流程:配置SRGB在IGP(is-is)中使能segmentrouting和NodeID修改IGP和TE的链路metric配置PCE我们这次主要关注配置PCE的过程。前面的配置可以参考:SR-TEPolicy(思科)—-explicitpath实验SR-TEPolicy(思科)—-dynamicpath实验P

    2022年9月7日
    0
  • pcap文件格式及文件解析[通俗易懂]

    pcap文件格式及文件解析[通俗易懂]第一部分:PCAP包文件格式一基本格式:文件头数据包头数据报数据包头数据报……二、文件头:文件头结构体sturctpcap_file_header{DWORDmagic;DWORDversio

    2022年8月3日
    8

发表回复

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

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