string常用截取字符串方法有很多,但是配合使用以下兩種,基本都能滿足要求:
find(string strSub, npos);
find_last_of(string strSub, npos);
其中strSub是需要尋找的子字符串,npos為查找起始位置。找到返回子字符串首次出現(xiàn)的位置,否則返回-1;
注:
(1)find_last_of的npos為從末尾開(kāi)始尋找的位置。
(2)下文中用到的strsub(npos,size)函數(shù),其中npos為開(kāi)始位置,size為截取大小
例1:直接查找字符串中是否具有某個(gè)字符串(返回"2")
1
2
3
4
5
6
7
8
9
10
11
|
std::string strPath = "E:\\數(shù)據(jù)\\2018\\2000坐標(biāo)系\\a.shp" int a = 0; if (strPath.find( "2018" ) == std::string::npos) { a = 1; } else { a = 2; } return a; |
例2:查找某個(gè)字符串的字符串(返回“E:”)
1
2
3
4
5
6
7
|
std::string strPath = "E:\\數(shù)據(jù)\\2018\\2000坐標(biāo)系\\a.shp" int nPos = strPath.find( "\\" ); if (nPos != -1) { strPath = strPath.substr(0, nPos); } return strPath; |
例3:查找某個(gè)字符串中某兩個(gè)子字符串之間的字符串(返回“2000坐標(biāo)系”)
1
2
3
4
5
6
7
8
9
10
|
std::string strPath = "E:\\數(shù)據(jù)\\2018\\2000坐標(biāo)系\\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; |
提高:遞歸獲取路徑名中的子目錄
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
//獲取路徑名中的子目錄:strPath為路徑名,strSubPath為輸出的子目錄, nSearch為從尾向前檢索的級(jí)別(默認(rèn)為1級(jí)) 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:\\數(shù)據(jù)\\2018\\2000坐標(biāo)系\\a.shp" ; std::string strSubPath = "" ; if (_GetSubPath(strPath, strSubPath, 1) { printf (“返回 'a.shp' ”); } if (_GetSubPath(strPath, strSubPath, 2) { printf (“返回 '2000坐標(biāo)系' ”); } } |
以上所述是小編給大家介紹的C++ string常用截取字符串方法詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!