我有几个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”时,它可以正常工作。 感谢
答案 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”编码。