前端截取字元串的方法「c++截取字元串」

字元串截取我想每個程序猿不管是新手還是老手都很熟悉了,像C++里的substr()方法就十分好用,但是這個方法需要知道你要截取位置的起始位置和需要截取的字元串長度,又或者需要知道截取的起始位置和停止位置。

背景

上面說的substr方法在截取不確定長度字元串和一次性截取多段子字元串時用起來不是很方便。小編就遇到這樣的問題,下面來詳細講講:

現在有一串格式固定但是長度不確定的字元串,例如:set(「
mill_ed.8.f_steptools.1.st_profile」, 「face」, 50.800);這樣一個字元串,他的結構是有規律的,都是由「.」分隔。

C++巧用正則一次性截取多段子字元串

如上,我需要截取標紅色的部分,其他部分都是固定的,按照常規方法我是可以先用「.」將字元串分割,然後再有部分的再分別去截取。但是我嫌麻煩,於是我就想到了正則表達式,想著能不能用正則去將我需要的字元匹配出來。

實現

直接上代碼吧:

C++巧用正則一次性截取多段子字元串

先看下運行結果吧:

C++巧用正則一次性截取多段子字元串

怎麼樣一次性將所有需要的子字元串全部截取出來了,是不是很方便快捷呢?(大家注意一下這裡,result容器內的第一項是匹配成功的整字元串,後面的才是小括弧中()匹配條件的子字元串)。

詳解

接下來我們來了解一下C++正則的一些基本用法吧。我們在用C++的正則的時候需要引入regex庫#include<regex>,這個庫裡面有哪些東西呢?

C++巧用正則一次性截取多段子字元串

這裡的函數和類型我就不講了,主要用到regex_match方法。然後將目標字元串與你得正則表達式去匹配,得到的匹配結果全部在smatch類型的容器中。其中最終要的主要是regex正則表達式

regex pattern = regex(“set\(“.*)\.(\d+)\.(.*)\.(\d+)\.st_profile”,.*”([a-z]+)”,(.*)\).*”);這裡是核心,這裡用到的正則知識其實都是最基本的,不是很複雜,如果有不懂得小夥伴自己去看下正則相關的知識,正則是與編程語言無關的都是通用的。大概講一下這裡用到的幾個通配符的意思:(截圖來源菜鳥教程)

C++巧用正則一次性截取多段子字元串

需要特別說明的是你需要匹配出來的子字元串的表達式一定要用小括弧「()」括起來,不然的話匹配結果是不會進入到smatch容器里去的,我們驗證一下,我將第一個子表達式的小括弧「()」去掉我們看一下結果:regex pattern = regex(“set\(“.*\.(\d+)\.(.*)\.(\d+)\.st_profile”,.*”([a-z]+)”,(.*)\).*”);

運行結果是:

C++巧用正則一次性截取多段子字元串

我們看到結果與上一次比少了mill_ed這一項。

希望對大家有幫助,如果大家以後在處理字元串有這種需求的話可以嘗試一下這種方法,我個人覺得用起來是很方便快捷的。最後給大家附上源代碼吧

#include <stdio.h>
#include <iostream>
#include <regex>
using namespace std;
int main()
{
	string str("set("mill_ed.8.f_steptools.1.st_profile","face", 50.800);");
	regex pattern = regex("set\("(.*)\.(\d+)\.(.*)\.(\d+)\.st_profile",.*"([a-z]+)",(.*)\).*");	
	smatch result ;
	bool isMatch = regex_match(str,result,pattern);
	for (int i = 0; i < result.size(); i++)
	{
		cout<<result[i]<<endl;
	}
	system("pause");
	return 0 ;
}

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/203810.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-07 12:11
下一篇 2024-12-07 12:11

相關推薦

發表回復

登錄後才能評論