Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/qt/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP显示以字母开头和后面的字符串_Php_Mysql_Internationalization - Fatal编程技术网

PHP显示以字母开头和后面的字符串

PHP显示以字母开头和后面的字符串,php,mysql,internationalization,Php,Mysql,Internationalization,我正在处理一个过滤系统,该系统目前正在用PHP开发,我在尝试向用户口述时遇到了麻烦 我从数据库中获取一个按姓氏排序的用户列表,这给了我们一个理论列表,如下所示: [ { "first name" : "Bob", "Last name" : "Éthier" }, { "first name" : "Paul", "Last name" : "Foo" }, { "first name" : "Alice", "Last n

我正在处理一个过滤系统,该系统目前正在用PHP开发,我在尝试向用户口述时遇到了麻烦

我从数据库中获取一个按姓氏排序的用户列表,这给了我们一个理论列表,如下所示:

[
  {
    "first name" : "Bob",
    "Last name"  : "Éthier"
  },
  {
    "first name" : "Paul",
    "Last name"  : "Foo"
  },
  {
    "first name" : "Alice",
    "Last name"  : "Smith"
  },
]
现在,当我试图从某个字母“a,B,C,…”开始列出上述用户时,问题就出现了

如果我要做这样的事情

if(strtoupper(substr($arr["Last name"], 0, 1)) >= $filterLetter)
   // Add account to display list to eventually show on page
我希望发生的是,当我选择字母“F”作为过滤器时,我的列表显示F及以上,因此基本上它将从每个其他人开始,并最终继续显示Smith等

当前发生的情况是,如果我选择的字母过滤器位于某个重音字符之上,则字符串会比较程序的一部分错误,并认为它是好的,然后显示它

目前,当我选择F作为我的“开始索引”时,BobÉthier显示,尽管它不应该出现,但我真的不知道为什么会出现这种情况。这似乎发生在每一个重音字母上,而不仅仅是É

我真的觉得“É”>F应该是假的,但就我而言,它是真的,所以我遗漏了什么


编辑:我的数据库系统是:MySql,我的字符集是latin1,排序规则是latin1\u swedish\u ci(这很可能是问题的一部分),字符确实正确地显示在页面上。

您可以使用下面给定的函数将重音字符串转换为普通字符串,然后继续进行必要的检查

function removeAccents($str) {
  $a = array('À', 'Á', 'Â', 'Ã', 'Ä', 'Å', 'Æ', 'Ç', 'È', 'É', 'Ê', 'Ë', 'Ì', 'Í', 'Î', 'Ï', 'Ð', 'Ñ', 'Ò', 'Ó', 'Ô', 'Õ', 'Ö', 'Ø', 'Ù', 'Ú', 'Û', 'Ü', 'Ý', 'ß', 'à', 'á', 'â', 'ã', 'ä', 'å', 'æ', 'ç', 'è', 'é', 'ê', 'ë', 'ì', 'í', 'î', 'ï', 'ñ', 'ò', 'ó', 'ô', 'õ', 'ö', 'ø', 'ù', 'ú', 'û', 'ü', 'ý', 'ÿ', 'Ā', 'ā', 'Ă', 'ă', 'Ą', 'ą', 'Ć', 'ć', 'Ĉ', 'ĉ', 'Ċ', 'ċ', 'Č', 'č', 'Ď', 'ď', 'Đ', 'đ', 'Ē', 'ē', 'Ĕ', 'ĕ', 'Ė', 'ė', 'Ę', 'ę', 'Ě', 'ě', 'Ĝ', 'ĝ', 'Ğ', 'ğ', 'Ġ', 'ġ', 'Ģ', 'ģ', 'Ĥ', 'ĥ', 'Ħ', 'ħ', 'Ĩ', 'ĩ', 'Ī', 'ī', 'Ĭ', 'ĭ', 'Į', 'į', 'İ', 'ı', 'IJ', 'ij', 'Ĵ', 'ĵ', 'Ķ', 'ķ', 'Ĺ', 'ĺ', 'Ļ', 'ļ', 'Ľ', 'ľ', 'Ŀ', 'ŀ', 'Ł', 'ł', 'Ń', 'ń', 'Ņ', 'ņ', 'Ň', 'ň', 'ʼn', 'Ō', 'ō', 'Ŏ', 'ŏ', 'Ő', 'ő', 'Œ', 'œ', 'Ŕ', 'ŕ', 'Ŗ', 'ŗ', 'Ř', 'ř', 'Ś', 'ś', 'Ŝ', 'ŝ', 'Ş', 'ş', 'Š', 'š', 'Ţ', 'ţ', 'Ť', 'ť', 'Ŧ', 'ŧ', 'Ũ', 'ũ', 'Ū', 'ū', 'Ŭ', 'ŭ', 'Ů', 'ů', 'Ű', 'ű', 'Ų', 'ų', 'Ŵ', 'ŵ', 'Ŷ', 'ŷ', 'Ÿ', 'Ź', 'ź', 'Ż', 'ż', 'Ž', 'ž', 'ſ', 'ƒ', 'Ơ', 'ơ', 'Ư', 'ư', 'Ǎ', 'ǎ', 'Ǐ', 'ǐ', 'Ǒ', 'ǒ', 'Ǔ', 'ǔ', 'Ǖ', 'ǖ', 'Ǘ', 'ǘ', 'Ǚ', 'ǚ', 'Ǜ', 'ǜ', 'Ǻ', 'ǻ', 'Ǽ', 'ǽ', 'Ǿ', 'ǿ', 'Ά', 'ά', 'Έ', 'έ', 'Ό', 'ό', 'Ώ', 'ώ', 'Ί', 'ί', 'ϊ', 'ΐ', 'Ύ', 'ύ', 'ϋ', 'ΰ', 'Ή', 'ή');
  $b = array('A', 'A', 'A', 'A', 'A', 'A', 'AE', 'C', 'E', 'E', 'E', 'E', 'I', 'I', 'I', 'I', 'D', 'N', 'O', 'O', 'O', 'O', 'O', 'O', 'U', 'U', 'U', 'U', 'Y', 's', 'a', 'a', 'a', 'a', 'a', 'a', 'ae', 'c', 'e', 'e', 'e', 'e', 'i', 'i', 'i', 'i', 'n', 'o', 'o', 'o', 'o', 'o', 'o', 'u', 'u', 'u', 'u', 'y', 'y', 'A', 'a', 'A', 'a', 'A', 'a', 'C', 'c', 'C', 'c', 'C', 'c', 'C', 'c', 'D', 'd', 'D', 'd', 'E', 'e', 'E', 'e', 'E', 'e', 'E', 'e', 'E', 'e', 'G', 'g', 'G', 'g', 'G', 'g', 'G', 'g', 'H', 'h', 'H', 'h', 'I', 'i', 'I', 'i', 'I', 'i', 'I', 'i', 'I', 'i', 'IJ', 'ij', 'J', 'j', 'K', 'k', 'L', 'l', 'L', 'l', 'L', 'l', 'L', 'l', 'l', 'l', 'N', 'n', 'N', 'n', 'N', 'n', 'n', 'O', 'o', 'O', 'o', 'O', 'o', 'OE', 'oe', 'R', 'r', 'R', 'r', 'R', 'r', 'S', 's', 'S', 's', 'S', 's', 'S', 's', 'T', 't', 'T', 't', 'T', 't', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'W', 'w', 'Y', 'y', 'Y', 'Z', 'z', 'Z', 'z', 'Z', 'z', 's', 'f', 'O', 'o', 'U', 'u', 'A', 'a', 'I', 'i', 'O', 'o', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'A', 'a', 'AE', 'ae', 'O', 'o', 'Α', 'α', 'Ε', 'ε', 'Ο', 'ο', 'Ω', 'ω', 'Ι', 'ι', 'ι', 'ι', 'Υ', 'υ', 'υ', 'υ', 'Η', 'η');
  return str_replace($a, $b, $str);
}
$str
是重音字符串,函数返回的结果将是存储在
$normalString

$str = 'Chloé'
$normalString = removeAccents($str);

这样,重音字符就不会有任何问题。

您可以使用下面给定的函数将重音字符串转换为普通字符串,然后继续进行必要的检查

function removeAccents($str) {
  $a = array('À', 'Á', 'Â', 'Ã', 'Ä', 'Å', 'Æ', 'Ç', 'È', 'É', 'Ê', 'Ë', 'Ì', 'Í', 'Î', 'Ï', 'Ð', 'Ñ', 'Ò', 'Ó', 'Ô', 'Õ', 'Ö', 'Ø', 'Ù', 'Ú', 'Û', 'Ü', 'Ý', 'ß', 'à', 'á', 'â', 'ã', 'ä', 'å', 'æ', 'ç', 'è', 'é', 'ê', 'ë', 'ì', 'í', 'î', 'ï', 'ñ', 'ò', 'ó', 'ô', 'õ', 'ö', 'ø', 'ù', 'ú', 'û', 'ü', 'ý', 'ÿ', 'Ā', 'ā', 'Ă', 'ă', 'Ą', 'ą', 'Ć', 'ć', 'Ĉ', 'ĉ', 'Ċ', 'ċ', 'Č', 'č', 'Ď', 'ď', 'Đ', 'đ', 'Ē', 'ē', 'Ĕ', 'ĕ', 'Ė', 'ė', 'Ę', 'ę', 'Ě', 'ě', 'Ĝ', 'ĝ', 'Ğ', 'ğ', 'Ġ', 'ġ', 'Ģ', 'ģ', 'Ĥ', 'ĥ', 'Ħ', 'ħ', 'Ĩ', 'ĩ', 'Ī', 'ī', 'Ĭ', 'ĭ', 'Į', 'į', 'İ', 'ı', 'IJ', 'ij', 'Ĵ', 'ĵ', 'Ķ', 'ķ', 'Ĺ', 'ĺ', 'Ļ', 'ļ', 'Ľ', 'ľ', 'Ŀ', 'ŀ', 'Ł', 'ł', 'Ń', 'ń', 'Ņ', 'ņ', 'Ň', 'ň', 'ʼn', 'Ō', 'ō', 'Ŏ', 'ŏ', 'Ő', 'ő', 'Œ', 'œ', 'Ŕ', 'ŕ', 'Ŗ', 'ŗ', 'Ř', 'ř', 'Ś', 'ś', 'Ŝ', 'ŝ', 'Ş', 'ş', 'Š', 'š', 'Ţ', 'ţ', 'Ť', 'ť', 'Ŧ', 'ŧ', 'Ũ', 'ũ', 'Ū', 'ū', 'Ŭ', 'ŭ', 'Ů', 'ů', 'Ű', 'ű', 'Ų', 'ų', 'Ŵ', 'ŵ', 'Ŷ', 'ŷ', 'Ÿ', 'Ź', 'ź', 'Ż', 'ż', 'Ž', 'ž', 'ſ', 'ƒ', 'Ơ', 'ơ', 'Ư', 'ư', 'Ǎ', 'ǎ', 'Ǐ', 'ǐ', 'Ǒ', 'ǒ', 'Ǔ', 'ǔ', 'Ǖ', 'ǖ', 'Ǘ', 'ǘ', 'Ǚ', 'ǚ', 'Ǜ', 'ǜ', 'Ǻ', 'ǻ', 'Ǽ', 'ǽ', 'Ǿ', 'ǿ', 'Ά', 'ά', 'Έ', 'έ', 'Ό', 'ό', 'Ώ', 'ώ', 'Ί', 'ί', 'ϊ', 'ΐ', 'Ύ', 'ύ', 'ϋ', 'ΰ', 'Ή', 'ή');
  $b = array('A', 'A', 'A', 'A', 'A', 'A', 'AE', 'C', 'E', 'E', 'E', 'E', 'I', 'I', 'I', 'I', 'D', 'N', 'O', 'O', 'O', 'O', 'O', 'O', 'U', 'U', 'U', 'U', 'Y', 's', 'a', 'a', 'a', 'a', 'a', 'a', 'ae', 'c', 'e', 'e', 'e', 'e', 'i', 'i', 'i', 'i', 'n', 'o', 'o', 'o', 'o', 'o', 'o', 'u', 'u', 'u', 'u', 'y', 'y', 'A', 'a', 'A', 'a', 'A', 'a', 'C', 'c', 'C', 'c', 'C', 'c', 'C', 'c', 'D', 'd', 'D', 'd', 'E', 'e', 'E', 'e', 'E', 'e', 'E', 'e', 'E', 'e', 'G', 'g', 'G', 'g', 'G', 'g', 'G', 'g', 'H', 'h', 'H', 'h', 'I', 'i', 'I', 'i', 'I', 'i', 'I', 'i', 'I', 'i', 'IJ', 'ij', 'J', 'j', 'K', 'k', 'L', 'l', 'L', 'l', 'L', 'l', 'L', 'l', 'l', 'l', 'N', 'n', 'N', 'n', 'N', 'n', 'n', 'O', 'o', 'O', 'o', 'O', 'o', 'OE', 'oe', 'R', 'r', 'R', 'r', 'R', 'r', 'S', 's', 'S', 's', 'S', 's', 'S', 's', 'T', 't', 'T', 't', 'T', 't', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'W', 'w', 'Y', 'y', 'Y', 'Z', 'z', 'Z', 'z', 'Z', 'z', 's', 'f', 'O', 'o', 'U', 'u', 'A', 'a', 'I', 'i', 'O', 'o', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'U', 'u', 'A', 'a', 'AE', 'ae', 'O', 'o', 'Α', 'α', 'Ε', 'ε', 'Ο', 'ο', 'Ω', 'ω', 'Ι', 'ι', 'ι', 'ι', 'Υ', 'υ', 'υ', 'υ', 'Η', 'η');
  return str_replace($a, $b, $str);
}
$str
是重音字符串,函数返回的结果将是存储在
$normalString

$str = 'Chloé'
$normalString = removeAccents($str);

这样,重音字符就不会有任何问题。

您可以使用iconv删除重音符号。确保正确设置区域设置,否则iconv可能返回意外字符。以下方面应起作用:

setlocale(LC_ALL, "en_US.utf8");
$char = mb_substr($arr["Last name"], 0, 1, 'UTF-8');
$char = iconv('UTF-8','ASCII//TRANSLIT',$char);
然后使用$char与索引进行比较


编辑:substr不适用于重音字符,使用mb_substr并传递UTF-8作为编码可以解决此问题。

您可以使用iconv删除变音符号。确保正确设置区域设置,否则iconv可能返回意外字符。以下方面应起作用:

setlocale(LC_ALL, "en_US.utf8");
$char = mb_substr($arr["Last name"], 0, 1, 'UTF-8');
$char = iconv('UTF-8','ASCII//TRANSLIT',$char);
然后使用$char与索引进行比较


编辑:substr不能处理重音字符,使用mb_substr并传递UTF-8作为编码可以解决问题。

可能是多字节,请尝试。。。您在MySQL表中使用过UTF-8排序规则吗?@RaviManiyar这里没有关于MySQL的内容。@user3783243-是的,请检查OP所述的第二行。@RaviManiyar OP正确地获得了页面上输出的内容,因此推测它是正确的。而且
mysql
不是唯一的
数据库。。。您在MySQL表中使用过UTF-8排序规则吗?@RaviManiyar这里没有关于MySQL的内容。@user3783243-是的,请检查OP所述的第二行。@RaviManiyar OP正确地获得了页面上输出的内容,因此推测它是正确的。而且
mysql
不是唯一的
数据库
setlocale(LC_ALL,“en_US.utf8”)$char=substr(“Éthier”,0,1)$char=iconv('UTF-8','ASCII//translatit',$char);var_dump($char)--这将打印
bool(false)
。去除重音可能是一个糟糕的计划,因为在某些语言中,它们会影响顺序。
setlocale(LC_ALL,“en_US.utf8”)$char=substr(“Éthier”,0,1)$char=iconv('UTF-8','ASCII//translatit',$char);var_dump($char)--这打印出
bool(false)
。去除重音可能是一个糟糕的计划,因为在某些语言中,它们会影响顺序。在某些语言中,“a”和“Å”不是同一回事,“Æ”和“AE”肯定不是。还有像“þ”和“ð”这样的字母根本不是重音。@tadman我完全同意。此功能只是转换并帮助用户轻松过滤,而不会出现任何问题。我没有提到任何地方可以转换和保存转换后的字符串。我也不是说,我是说排序问题比这段琐碎的代码所暗示的要复杂得多。在某些语言中,“A”和“Å”不是一回事,“Æ”和“AE”肯定不是。还有像“þ”和“ð”这样的字母根本不是重音。@tadman我完全同意。此功能只是转换并帮助用户轻松过滤,而不会出现任何问题。我没有提到任何地方可以转换和保存转换后的字符串。我也不是说,我是说排序问题比这段微不足道的代码所暗示的要复杂得多。