1

我有两个向量,一个包含我的正则表达式,一个包含将根据正则表达式检查的字符串,其中大多数都可以正常工作,除了这个(如下所示)字符串是正确的字符串并且与正则匹配表达式,但它输出不正确而不是正确。

输入字符串

.C/IATA

代码如下

std::string errorMessages [6][6] = {
    {
        "Correct Corparate Name\n",
    },
    {
        "Incorrect Format for Corporate Name\n",
    }
};

std::vector<std::string> el;
split(el,message,boost::is_any_of("\n"));
std::string a = ("");

for(int i = 0; i < el.size(); i++)
{
    if(el[i].substr(0,3) == ".C/")
    {
        DCS_LOG_DEBUG("--------------- Validating .C/ ---------------");
        output.push_back("\n--------------- Validating .C/ ---------------\n");
        str = el[i].substr(3);
        split(st,str,boost::is_any_of("/"));
        for (int split_id = 0 ; split_id < splitMask.size() ; split_id++ )
        {
            boost::regex const string_matcher_id(splitMask[split_id]);
            if(boost::regex_match(st[split_id],string_matcher_id))
            {
                a = errorMessages[0][split_id];
                DCS_LOG_DEBUG("" << a )
            }
            else
            {
                a = errorMessages[1][split_id];
                DCS_LOG_DEBUG("" << a)
            }
                output.push_back(a);
        }
    }
    else
    {
        DCS_LOG_DEBUG("Do Nothing");
    }

st[split_id] = "国际航空运输协会"

splitMask[split_id] = "[a-zA-Z]{1,15}" <---

但它仍然输出公司名称的格式不正确

我不明白为什么它应该正确时打印不正确,有人可以在这里帮助我吗?

4

1 回答 1

0

你的正则表达式和周围的逻辑是好的。

您需要扩展您的日志记录并在调用 to 之前打印相关部分,splitMaskst仔细boost::regex_match检查这些值是否是您认为的值。用一些标点符号将它们打印出来,并确定字符串的长度。

您可能知道,boost::regex_match只有在整个字符串都匹配时才找到匹配项;因此,如果某处有不可打印的字符,或者可能是尾随空格字符,这将完美地解释您所看到的结果。

于 2012-03-18T21:13:14.983 回答