Lig*_*ker 4 php regex case-insensitive non-ascii-characters
我想做典型的高亮代码.所以我有类似的东西:
$valor = preg_replace("/(".$_REQUEST['txt_search'].")/iu", "<span style='background-color:yellow; font-weight:bold;'>\\1</span>", $valor);
Run Code Online (Sandbox Code Playgroud)
现在,请求单词可能类似于"josé".有了它,我也想要"jose"或"JOSÉ"或"José"等.
有了这个表达式,如果我写"josé",它会匹配"josé"和"JOSÉ"(以及所有案例变体).它始终只与重音变体匹配.如果我搜索"jose",它会匹配"JOSE","jose","Jose"而不是重音符号.所以我部分地想要我想要的,因为我对重音和非重音分别不区分大小写.
我需要它完全结合,这意味着重音(unicode)不敏感,所以我可以搜索"jose",并突出显示"josé","josÉ","José","JOSE","JOSÉ","JoSé",... .
我不想在单词上替换重音,因为当我在屏幕上打印时,我需要看到真实的单词.
有任何想法吗?
谢谢!
您可以尝试创建一个函数来创建基于txt_search的正则表达式,将所有可能的匹配替换为所有可能的匹配,如下所示:
function search_term($txt_search) {
$search = preg_quote($txt_search);
$search = preg_replace('/[aàáâãåäæ]/iu', '[aàáâãåäæ]', $search);
$search = preg_replace('/[eèéêë]/iu', '[eèéêë]', $search);
$search = preg_replace('/[iìíîï]/iu', '[iìíîï]', $search);
$search = preg_replace('/[oòóôõöø]/iu', '[oòóôõöø]', $search);
$search = preg_replace('/[uùúûü]/iu', '[uùúûü]', $search);
// add any other character
return $search;
}
Run Code Online (Sandbox Code Playgroud)
然后将结果用作preg_replace上的正则表达式.