我想安装一个条件。我已经尝试了很多,但没有成功。有人会这么友善并会帮助我吗?

我的目标:如果SharedKeys为true,则匹配元素(A B C D)。



正则表达式:(?!\")[A-Z]*?(?=\")
匹配元素:A B C D

更新:(SharedKeys)?(?(1)|(?!\")[A-Z]*?(?=\"))
匹配元素:SharedKeys A B C D

链接:https://regex101.com/r/WFxZh4/1

我想我现在有需要的东西,也许可以帮助别人。



结果:(SharedKeys|BlaBla)?(?(1)|(?!\")[A-Z]*?(?=\"))
匹配元素:共享密钥A B C D BlaBla B B C

C++的结果:[A-Za-z]+|(?!\")[A-Z]*?(?=\")(std::regex)

最佳答案

std::regex:

std::string s1( R"(SharedKeys = "A","B","C","D")" );
std::regex rx( "(SharedKeys)?(?(1)|[A-Z](?=\\\"))" );
std::match_results< std::string::const_iterator > mr;

while( std::regex_search( s1, mr, rx ) ){
    std::cout << mr.str() << '\n';
    s1 = mr.suffix().str();
}

输出:
terminate called after throwing an instance of 'std::regex_error'
what():  Invalid special open parenthesis. Aborted (core dumped)

boost::regex:
std::string s1( R"(SharedKeys = "A","B","C","D")" );
boost::regex rx( "(SharedKeys)?(?(1)|[A-Z](?=\\\"))" );
boost::match_results< std::string::const_iterator > mr;

while( boost::regex_search( s1, mr, rx ) ){
    std::cout << mr.str() << '\n';
    s1 = mr.suffix().str();
}

输出:
SharedKeys
A
B
C
D

在这里您可以看到这两种口味之间的区别:

c&#43;&#43; - 正则表达式搜索文本,然后匹配元素-LMLPHP

source of the screenshot

注意。 std::regex有问题,尤其是gcc version 6.3.0 and lower versions

关于c++ - 正则表达式搜索文本,然后匹配元素,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/44909227/

10-12 20:50