C++转义短语子字符串
C++ Escape Phrase Substring
我正在尝试解析来自服务器的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;
}