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-08
C語言數(shù)據(jù)結構與算法之隊列的實現(xiàn)詳解
隊列只允許在一端進行插入數(shù)據(jù)操作,在另一端進行刪除數(shù)據(jù)操作的特殊線性表,隊列具有先進先出FIFO(First In First Out)的原則。本文將通過實例詳細說說隊列的實現(xiàn),需要的可以學習一下2022-10-10

