繁体   English   中英

使用boost将出现的字符替换为seq数字

[英]replace the occurrence of character with a seq number using boost

如何用包含出现次数的字符串替换字符的多次出现。 例如,如果我有以下表达式。

insert into emp values(?,?,?)

我想要以下转换后的字符串。

insert into emp values(_p_1,_p_2,_p_3)

我正在尝试使用boost正则表达式。

谁能告诉我如何使用boost c ++(无迭代或最小迭代)实现这一目标。

目前,我正在使用以下方法:

        std::wstring q=L"insert into emp values(?,?,?)";
        auto loc = q.find(L"?");
        auto len = wcslen(L"?");
        auto c=1;
        while(loc != std::wstring::npos)
        {
            q.replace(loc, len , L"_p_"+to_wstring(c));
            c++;
            loc = q.find(L"?");
        }
        cout<<q.c_str();

请提出更好,更有效的方法。

我只是忘记了正则表达式,而是尝试使用Boost做这个简单的事情。

这就像问“如何使用Boost正则表达式将1加到变量中”?

最好的答案,恕我直言,而是使用++来执行加1的任务,并使用循环将特殊字符替换为字符串。

string const query_format = "insert into emp values(?,?,?)";
string const params[] = {"_p_1", "_p_2", "_p3"};

string query;
string const* p = params;
for( char const c : query_format )
{
    if( c == '?' ) { query += *p++; } else { query += c; }
}
// Use `query`

可以选择将其包装为replace功能。

免责声明:编译器未触及的代码。


如果您控制query_format字符串,为什么不使占位符与Boost format兼容。


重新括号要求

,没有迭代或迭代次数最少

无论您如何执行,都涉及迭代。 您可以将迭代隐藏在函数名称的后面,仅此而已。 从逻辑上讲,实际上避免迭代是不可能的,并且将其隐藏在函数名后面是微不足道的(完全琐碎的)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM