簡體   English   中英

使用C ++功能解析字符串的最有效方法

[英]most efficient way to parse a string using c++ features

這可能是一個愚蠢的問題(我希望不是),但是這引起了我的注意,我正在嘗試解決。 使用C ++功能解析字符串的最有效方法是什么? 我很感謝大家的評論,我敢肯定其他人也都願意成為一個更好的程序員! 現在,以我目前的知識,這就是我現在要做的事情:

#include <iostream>
#include <string>
using std::cout;
using std::string;
using std::endl;
void parseLine(string &line)
{
    constexpr char DELIMITER_ONE = '|';
    constexpr char DELIMITER_TWO = '[';
    for (int i = 0; i < line.length(); i++)
    {
        if (line[i] == DELIMITER_ONE || line[i] == DELIMITER_TWO)
        {
            line.erase(i, 1);
        }
    }
    cout << line << endl;
}
int main()
{
    std::string testString = "H|el[l|o|";
    parseLine(testString);

    system("pause");
    return 0;
}
line.erase(
    std::remove_if(line.begin(), line.end(),
        [](char c) { return c == DELIMITER_ONE || c == DELIMITER_TWO; }
    ),
    line.end()
);

另請參閱: 刪除刪除慣用語

另一種方法是使用boost regex庫。 檢查以下代碼:

#include <iostream>
#include <string>
#include <boost/regex.hpp>

int main(){
  std::string testString = "H|el[l|o|";
  boost::regex rx("\\||\\[");
  std::string replace = "";
  std::string out = boost::regex_replace(testString, rx, replace);
  std::cout << out << std::endl;
}

C ++ 14現在包括正則表達式標准:

#include <iostream>
#include <string>
#include <regex>

std::string parseLine(const std::string& line);

int main() {
    std::string testString = "H|el[l|o|";
    std::string result = parseLine(testString);
    std::cout << result << std::endl;
    system("pause");
    return 0;
}

std::string parseLine(const std::string& line) {

    std::string input_string;
    std::string result;

    std::smatch sm;
    std::regex r("([a-zA-Z]+)");

    for(input_string = line; std::regex_search(input_string, sm, r); input_string = sm.suffix()) {
        result.append(sm[0].str());
    }
    return result;
}

暫無
暫無

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

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