C++字符串的截取問題
更新時間:2023年08月08日 10:59:23 作者:休息一下接著來
這篇文章主要介紹了C++字符串的截取問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
C++字符串截取
按照字符串截取
/** ?* @brief ? 按照指定的字符串截取字符串 ?* @param str ?需要截取的字符串 ?* @param ?pattern ?按照該字符串截取 ?* @return 截取好的字符串vector ?*/ std::vector<std::string> splitStr(std::string str, std::string pattern) { ? ? std::string::size_type pos; ? ? std::vector<std::string> result; ? ? //擴展字符串以方便操作 ? ? str += pattern; ? ? int size = str.size(); ? ? for (int i = 0; i < size; i++) ? ? { ? ? ? ? pos = str.find(pattern, i); ? ? ? ? if (pos < size) ? ? ? ? { ? ? ? ? ? ? std::string s = str.substr(i, pos - i); ? ? ? ? ? ? result.push_back(s); ? ? ? ? ? ? i = pos + pattern.size() - 1; ? ? ? ? } ? ? } ? ? return result; }
按照字符截取
/** ?* @brief ? 按照指定的字符截取字符串 ?* @param str ?需要截取的字符串 ?* @param ?pattern ?按照該字符截取 ?* @return 截取好的字符串vector ?*/ std::vector<std::string> splitStr(std::string str, char pattern) { ? ? // 擴展字符串,方便后面進行操作 ? ? str.push_back(pattern); ? ? std::vector<std::string> result; ? ? auto iter = str.cbegin(); ? ? auto iter2 = iter; ? ? for (iter; iter != str.cend(); ++iter) ? ? { ? ? ? ? if (*iter == pattern) ? ? ? ? { ? ? ? ? ? ? result.push_back(string(iter2, iter)); ? ? ? ? ? ? iter2 = iter + 1; ? ? ? ? } ? ? } ? ? return result; }
C++截取部分字符串(類似python的切片)
1.首先在python中取一個字符串的多少位,使用s[begin:end]。
2.c++中使用一個函數(shù)來截取字符串位
頭文件:
#include <string> //注意沒有.h string.h是C的標準字符串函數(shù)數(shù),c++中一般起名為ctring. 而string頭文件是C++的字符串頭文件。
函數(shù)原型:
string substr(int pos = 0,int n ) const;
參數(shù)說明:
- 參數(shù)1:pos是必填參數(shù)
- 參數(shù)2:n是可參數(shù),表示取多少個字符,不填表示截取到末尾
該函數(shù)功能為:返回從pos開始的n個字符組成的字符串,原字符串不被改變
# include <iostream> # include <string> using namespace std; int main() { ? ? const string image_name = "0170.bmp"; ? ? print(image_name.substr(0, 4)); ? ? return 0; }
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
OpenCV邊緣提取算法流程的實現(xiàn)(附DEMO)
本文主要介紹了OpenCV邊緣提取算法流程的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08C語言數(shù)據(jù)結構與算法之隊列的實現(xiàn)詳解
隊列只允許在一端進行插入數(shù)據(jù)操作,在另一端進行刪除數(shù)據(jù)操作的特殊線性表,隊列具有先進先出FIFO(First In First Out)的原則。本文將通過實例詳細說說隊列的實現(xiàn),需要的可以學習一下2022-10-10