从 std::string 中提取信息

Extract information from std::string

本文关键字:提取 信息 string std      更新时间:2023-10-16

与字符串相关的查询太多,但仍然存在一些疑问,因为每个字符串都是不同的,每个要求也不同。

我有一个这种形式的字符串:Random1A:Random1B::String1 Random2A:Random2B::String2 ... RandomNA:RandomNB::StringN

我想以这种形式返回一个字符串:String1 String2 ... StringN

简而言之,输入字符串看起来像A:B::Val1 P:Q::Val2,而o/p结果字符串看起来像"Val1Val2"。

PS:RandomsStrings是小(可变)长度的字母数字字符串。

std::string GetCoreStr ( std::string inputStr, int & vSeqLen )
{
std::string seqStr;
std::string strNew;
seqStr = inputStr;
size_t firstFind = 0;
while ( !seqStr.empty() )
{
firstFind = inputStr.find("::");
size_t lastFind = (inputStr.find(" ") < inputStr.length())? inputStr.find(" ") : inputStr.length();
strNew += inputStr.substr(firstFind+2, lastFind-firstFind-1);
vSeqStr = inputStr.erase( 0, lastFind+1 );
}
vSeqLen = strNew.length();
return strNew;
}

我想找回一个字符串String1String2...StringN.

我的代码有效,我得到了我选择的结果,但它不是最佳形式。我需要帮助来提高代码质量。

我最终用C-way做了这件事。

std::string GetCoreStr ( const std::string & inputStr )
{
std::string strNew;
for ( int i = 0; i < inputStr.length(); ++i )
{
if ( inputStr[i] == ':' && inputStr[i + 1] == ':' )
{
i += 2;
while ( ( inputStr[i] != ' ' && inputStr[i] != '' ) )
{
strNew += inputStr[i++];
}
if ( inputStr[i] == ' ' )
{ 
strNew += ' ';
}
}
}
return strNew;
}

我在决定如何调整偏移量时遇到困难。[...]

std::string getCoreString(std::string const& input)
{
std::string result;
// optional: avoid reallocations:
result.reserve(input.length());
// (we likely reserved too much – if you have some reliable hint how many
// input parts we have, you might subtract appropriate number)
size_t end = 0;
do
{
size_t begin = input.find("::", end);
// added check: double colon not found at all...
if(begin == std::string::npos)
break;
// single character variant is more efficient, if you need to find just such one:
end = std::min(input.find(' ', begin) + 1, input.length());
result.append(input.begin() + begin + 2, input.begin() + end);
}
while(end < input.length());
return result;
}

旁注:你不需要额外的"length"输出参数;它是多余的,因为返回的字符串包含相同的值......