有没有办法使用 PHP API 获取 pspell 支持的字典数组,最好是完整的人类可读名称?
目前我正在这样做:
$dicts = explode(PHP_EOL,rtrim(`aspell dicts`));
但这仍然没有给我人性化的版本,(例如,en_CA
可能是“英语 - 加拿大”)
解决方案
这是我想出的:
$dicts = explode(PHP_EOL,rtrim(`aspell dicts`));
$ltr = array();
foreach($dicts as $dict) {
if(preg_match('`^([a-z]+)$`',$dict,$m)) {
$lang = _iso639_1_to_lang_name($dict) ?: $dict;
} elseif(preg_match('`^([a-z]+)_([A-Z]+)$`',$dict,$m)) {
$lang = (_iso639_1_to_lang_name($m[1]) ?: $m[1]).' - '.(_country_code_to_adjectival($m[2])?:$m[2]);
} elseif(preg_match('`^([a-z]+)_([A-Z]+)-(.*)$`',$dict,$m)) {
$lang = (_iso639_1_to_lang_name($m[1]) ?: $m[1]).' - '.(_country_code_to_adjectival($m[2])?:$m[2]).' - '.ucwords(str_replace('_',' ',$m[3]));
} elseif(preg_match('`^([a-z]+)-(.*)$`',$dict,$m)) {
$lang = (_iso639_1_to_lang_name($m[1]) ?: $m[1]).' - '.ucwords(str_replace('_',' ',$m[2]));
} else {
$lang = $dict;
}
$ltr[$dict] = $lang;
}
这些函数只是根据我从 Wikipedia 上抓取的数据从 ISO 代码中查找全名。