簡體   English   中英

C ++正則表達式:分割字符串

[英]C++ regex: split the string

我正在嘗試搜索和拆分基於正則表達式的字符串。 假設我有一個名為var的字符串,看起來像

|   | | |-DeclRefExpr 0x5d91218 <col:5> 'int' lvalue Var 0x5d91120 'y' 'int'

現在我想把它分成

|   | | |-DeclRefExpr 0x5d91218 <col:5> 
int
 lvalue Var 0x5d91120 
y

int

我知道正則表達式將類似於[^'] *,但我不知道該怎么做。 到目前為止,我嘗試過的是:

#include <string.h>
#include <stdlib.h>
#include <iostream>
#include <regex>

using namespace std;

int main(){

    std::string var = "    |   | | |-DeclRefExpr 0x5d91218 <col:5> 'int' lvalue Var 0x5d91120 'y' 'int'";

    std::regex rgx("[^']*");
    std::smatch match;
    if (std::regex_search(var.begin(), var.end(), match, rgx)){
        cout << match[3] << endl;
    }
    return 0;
}

抱歉,我無法測試此代碼,但它也許可以工作。

std::string var = "|   | | |-DeclRefExpr 0x5d91218 <col:5> 'int' lvalue Var 0x5d91120 'y' 'int'";
std::regex wsaq_re("\\s*'|'+\\s*(?!')"); 
std::copy( std::sregex_token_iterator(var.begin(), var.end(), wsaq_re, -1),
    std::sregex_token_iterator(),
    std::ostream_iterator<std::string>(std::cout, "\n"));

除了@CasimiretHippolyte的方法,您還可以使用regex_search()

const regex r("(.*)'(.*)'(.*)'(.*)'(.*)'(.*)'");  
smatch sm;

if (regex_search(var, sm, r))
{
    for (int i=1; i<sm.size(); i++)
    {
        cout << sm[i] << endl;
    }
}

現場觀看: http//coliru.stacked-crooked.com/a/494ab2e0f1c5d420

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM