strcmp忽略重音,输出false

时间:2018-01-15 16:53:16

标签: c string compare strcmp

我有几个strcmp来获取布尔值,除非字符串包含重音,否则它们都能正常工作。

if(strcmp(arrayOfStrings[index], "Día de descanso") == 0

输出false而不是true。我一直在尝试使用转义序列进行比较,但我无法使其正常工作。

使用下一个函数将字符串添加到arrayOfStrings:

void introducirPlan()
{
  for(int i = 1; i <= 10; i++)
  {
    printf("Actividad del dia %d? ", i);
    scanf(" %[^\n]", diasEntrenamiento[i]);
  }
  printf("\n");
}

还有另一个函数用于检查使用strcmp添加的字符串:

bool compararDescanso(int idia)
{
  if(strcmp(diasEntrenamiento[idia], "Día de descanso") == 0)
  {
    return true;
  }
  if(strcmp(diasEntrenamiento[idia], "Dia de descanso") == 0)
  {
    return true;
  }
}

这看起来像strcmp输出false:

  while(cntImprEntr <= 10)
  {
    if(compararDescanso(cntImprEntr) == true)
    {
      printf(" D "); /*"D" never gets printed if string contains accent */
      columna++;
      dia++;
    }
    else
    {
      printf(" C ");
      columna++;
      dia++;
    }
    if(columna == 5)
    {
      printf("|");
    }
    printf(" ");
    cntImprEntr++;
    if(columna >= 7)
    {
      printf("\n");
      columna = 0;
    }
  }

有什么方法可以让strcmp不要忽略重音并给出真正的输出?当索引中的字符串包含“Dia”而不是“Día”时,它可以正常工作。 感谢

1 个答案:

答案 0 :(得分:0)

您的问题与文字编码有关。

虽然您没有说出来,但您可能正在使用Windows,并将终端用于您的程序。

问题是Windows使用的终端字符编码与“窗口”程序使用的字符编码不同(因此也就是文本编辑器)。

这意味着重音字符的代码是相同的。

首先要了解什么是unicode和charcater编码:https://www.joelonsoftware.com/2003/10/08/the-absolute-minimum-every-software-developer-absolutely-positively-must-know-about-unicode-and-character-sets-no-excuses/

第二件事,只需更改文本编辑器的编码以匹配终端的编码 - 我不确定在Español中用于Windows的编码,但在葡萄牙语中,终端的cp-852和“窗口的latin1” “(我敢打赌它也是西班牙语Windows的”latin1“)。

NB&GT;虽然微软在20世纪80年代仍然坚持使用这些编码,但世界其他地方,包括所有网络,都使用“utf-8”。因此,这种编码解决方法有利于您的代码工作并从中学习,但您确定应该专注于对任何注定要实际生产的东西使用“utf-8”编码。