Este não é necessariamente o melhor método, e com certeza não é fácil de usar, mas é fácil começar a trabalhar: aqui está um script Python para fazer isso.
Instale a biblioteca Python-fontconfig . Você pode obtê-lo da sua distribuição (por exemplo, sudo apt-get install python-fontconfig
no Debian e derivados) ou instalá-lo em seu diretório pessoal ( pip install --user python-fontconfig)
. Então você pode executar este script (salve-o como fc-search-codepoint
em um diretório em seu PATH
, por exemplo ~/bin
, tipicamente , e torne-o executável):
#!/usr/bin/env python2
import re, sys
import fontconfig
if len(sys.argv) < 1:
print('''Usage: ''' + sys.argv[0] + '''CHARS [REGEX]
Print the names of available fonts containing the code point(s) CHARS.
If CHARS contains multiple characters, they must all be present.
Alternatively you can use U+xxxx to search for a single character with
code point xxxx (hexadecimal digits).
If REGEX is specified, the font name must match this regular expression.''')
sys.exit(0)
characters = sys.argv[1]
if characters.startswith('U+'):
characters = unichr(int(characters[2:], 16))
else:
characters = characters.decode(sys.stdout.encoding)
regexp = re.compile(sys.argv[2] if len(sys.argv) > 2 else '')
font_names = fontconfig.query()
found = False
for name in font_names:
if not re.search(regexp, name): continue
font = fontconfig.FcFont(name)
if all(font.has_char(c) for c in characters):
print(name)
found = True
sys.exit(0 if found else 1)
Exemplo de uso:
$ fc-search-codepoint 🉃⼼😻🕲🝤
$ echo $?
1
Eu não tenho nenhuma fonte com todos esses caracteres.
$ fc-search-codepoint U+1F64D
/usr/share/fonts/truetype/unifont/unifont_upper.ttf
/usr/share/fonts/truetype/unifont/unifont_upper_csur.ttf