C - strcmp 忽略重音,输出 false



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

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

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

字符串使用下一个函数添加到 arrayOfString 中:

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输出是错误的:

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"时,它可以正常工作。 谢谢

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

虽然你没有说出来,但你可能正在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/

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

注意>虽然Microsoft坚持使用1980年代的这些编码,但世界其他地区,包括Web的所有内容,都使用"utf-8"。 因此,这种编码解决方法有利于您的代码工作并从中学习,但您肯定应该专注于对注定要实际投入生产的任何事物使用"utf-8"编码。

相关内容

  • 没有找到相关文章

最新更新