C++转义短语子字符串

C++ Escape Phrase Substring

本文关键字:字符串 短语 转义 C++      更新时间:2023-10-16

我正在尝试解析来自服务器的Web数据,并且我正在尝试找到我所拥有的更stl版本。

我的旧代码由一个for()循环组成,并根据一组转义字符检查字符串的每个字符,并使用字符串流来收集其余字符。我相信你可以想象,这种循环会导致读取 Web 数据时出现高故障点,因为我需要严格的语法检查。

我正在尝试开始使用 string::find 和 string::substr 函数,但我不确定最好的实现方式。

基本上,我想从服务器读取一串数据,不同的数据,用逗号分隔。(即 first,lastname,email@email.com)并在逗号处分隔,但读取中间的数据。

谁能提供任何建议?

我不确定您要解析哪种数据,但使用多层架构总是一个好主意。每一层应该实现一个抽象函数,每层应该只做一个工作(比如转义字符)。

您使用的层数取决于解码流所需的实际步骤

对于您的问题,我建议以下几层:

1st:通过 '"," 和 '' 标记化:转换为某种字符串向量

第二:解决转义:解码转义字符

你应该使用 std::stringstream,并使用循环处理字符。 除非你的格式非常简单(比如只有一个分隔符,没有转义),否则你不能真正使用任何标准函数。

对于学习体验,这是我最终用来将数据解析为地图的代码。可以使用 web_parse_resurn.err 查看是否命中了错误,或将其用于特定错误代码。

struct web_parse_return {
map<int,string> parsedata;
int err;
};
web_parse_return* parsewebstring(char* escapechar, char* input, int tokenminimum) {                 
int err = 0;
map<int,string> datamap;
if(input == "MISSING_INFO") { //a server-side string for data left out in the call
    err++;
}
else {
    char* nTOKEN;   
    char* TOKEN = strtok_s(input, escapechar,&nTOKEN);
    if(TOKEN != 0) { //if the escape character is found
        int tokencount = 0; 
        while(TOKEN != 0) {//since it finds the next occurrence, keep going
            datamap.insert(pair<int,string>(tokencount,TOKEN));
            TOKEN = strtok_s(NULL, escapechar,&nTOKEN);
            tokencount++;
        }
        if(tokencount < tokenminimum) //check that the right number was hit
            err++; //other wise, up the error count
    }
    else {
        err++;  
    }   
}
web_parse_return* p = new web_parse_return; //initializing a new struct
p->err = err;
p->parsedata = datamap;
return p;
}