gpt4 book ai didi

c - strcmp 忽略重音,输出 false

转载 作者:行者123 更新时间:2023-11-30 16:36:51 24 4
gpt4 key购买 nike

我有几个 strcmp 来获取 bool 值,除了字符串包含重音符号之外,它们都工作正常。

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

最佳答案

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

尽管您没有明说,但您很可能在 Windows 上工作,并在程序中使用终端。

问题是 Windows 对您的终端使用的字符编码与“窗口”程序(以及您的文本编辑器)使用的字符编码不同。

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

首先要了解什么是 unicode 和字符编码: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,“windowed”是 latin1 “(我敢打赌对于西类牙语 Windows 来说它也是“latin1”)。

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

关于c - strcmp 忽略重音,输出 false,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48267455/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com